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本 书 是 (MySQL 数据 库 应 用 与 开发 )( 姜 桂 洪 主编 ,2018 年 由 清华 大 学 出 版 社 出 版 ) 的 
配套 辅导 教材 。 书 中 采用 目前 实际 生产 和 教学 领域 内 应 用 广泛 的 MySQL 软件 ,利用 内 容 
丰富 的 习题 答案 、 涵 盖 MySQL 所 有 重要 知识 点 的 实验 基本 操作 、 典 型 的 模拟 试题 等 形式 ， 
从 多 视角 为 初学 者 提供 了 在 Windows 系列 平台 上 学 习 数 据 库 知 识 的 服务 环境 。 同 时 ,还 通过 
可 视 化 软件 及 综合 性 实验 介绍 了 MySQL 与 PHP 平台 相 结合 实现 数据 管理 的 常用 操作 。 

本 书 从 基本 操作 着 手 ,从 教学 实际 需求 出 发 ,结合 初学 者 的 认 知 规律 ,由 浅 入 深 、 精 心 选 
FE MySQL 数据 库 的 知识 点 ,以 数据 库 及 相关 数据 库 对 象 为 基础 ,以 备份 还原、 日 志 管 理 、 
性 能 优化 和 利用 PHP 语言 访问 MySQL 数据 等 数据 库 系统 管理 组 件 为 目标 ,以 形式 多 样 、 
内 容 丰 富 的 习题 和 参考 答案 对 基本 操作 进行 示范 ,与 主教 材 一 起 打造 出 比较 完整 的 立体 化 
课程 体系 。 

本 书 在 模块 内 容 安排 上 体现 循序 渐进 .重点 突出 的 特点 。 习 题解 答 部 分 中 ,每 章 都 配 有 
教学 内 容 的 重点 、 难 点 介绍 和 详细 的 习题 参考 答案 ,主要 目的 是 帮助 学 生 掌握 数据 库 的 基本 
概念 和 MySQL 语句 的 基本 规则 和 基本 操作 。 实 验 部 分 主要 帮助 学 生 进 一 步 强化 基本 单元 
操作 ,培养 学 生 独 立 操作 的 能 力 。 模 拟 题 可 以 让 学 生 在 掌握 好 所 学 知识 的 基础 上 ,进一步 了 
解 自己 学 习 本 课程 的 知识 水 平 。 通 过 本 书 提 供 的 指导 材料 ,学 生 可 以 在 自由 上 机 的 环境 下 ， 
完成 相关 数据 库 的 常用 操作 及 管理 。 

全 书 总 共 包 括 如 下 3 部 分 内 容 : 

第 1 部 分 包括 第 1 一 15 章 , 内 容 为 主教 材 的 习题 参考 答案 ,所 有 编程 题 的 答案 均 全 部 通 

第 2 部 分 包括 第 16 一 18 章 , 内 容 为 MySQL 软件 的 常用 实践 环境 配置 操作 MySQL 的 
可 视 化 软件 Navicat for MySQL 和 phpMyAdmin 的 详细 介绍 和 基本 操作 ,以 及 学 生 上 机 实 
验 时 需要 注意 的 问题 ,并 根据 教材 内 容 提供 16 个 配套 实验 。 实 验 操 作 步 又 清晰 、 完 整 且 有 
代表 性 。 

第 3 部 分 提供 6 套 模拟 试题 及 参考 答案 ,为 读者 学 习 MySQL 数据 库 提供 了 自我 检查 
知识 掌握 水 平 的 契机 , 旨 在 帮助 读者 了 解 和 检验 自己 的 学 习 情况 。 

全 书 由 姜 桂 洪 、 孙 福 振 、 苏 晶 等 老师 参与 编写 ,由 姜 桂 洪 统 稿 。 在 本 书 编写 过 程 中 还 参 
阅 了 大 量 的 数据 库 方面 的 文献 和 网 站 资料 ,在 此 对 提供 者 一 并 深 表 感谢 。 

由 于 作者 水 平 有 限 , 书 中 丝 漏 之 处 在 所 难免 ,恳请 读者 批评 指正 。 
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第 1 部 分 
《MySQL 数 据 库 应 用 与 开发 》 


习题 参考 答案 











学 习 导 读 : 

本 部 分 包括 (MySQL 数据 库 应 用 与 开发 》 第 1 一 15 章 的 教 
学 重点 和 难点 提示 ,以 及 所 有 习题 的 参考 答案 ,所 有 代码 均 在 
MySQL 5. 7. 17 版 本 的 环境 下 测试 通过 。 

每 章 习题 包括 选择 题 , 思 考题 和 上 机 练习 题 3 种 类 型 : 

CD 选择 填空 注重 基本 概念 和 基本 操作 的 知识 点 掌握 。 

(2) 思考 题 侧 重 基 本 概念 的 理解 。 

(3) 上 机 练习 题 侧重 的 是 基本 操作 的 练习 。 第 4 章 的 习题 
答案 还 附加 了 主教 材 和 指导 书 常 用 数据 库 teaching 89 4 25 44349 
数据 , 供 大 家 在 学 习 过 程 中 参考 。 

建议 在 学 习 过 程 中 ,通过 习题 熟悉 MySQL 数据 库 的 基本 
概念 和 基本 操作 。 不 要 满足 于 看 懂 程 序 或 习题 答案 ,要 多 动手 
做 练习 ,并且 要 达到 一 定 的 做 题 速 度 和 正确 率 。 在 此 基础 上 , 借 
助 于 网 络 或 其 他 工具 ,举一反三 ,解决 一 些 比 教 材 习 题 更 新 颖 、 
算法 更 复杂 的 问题 。 





第 12 MySQL 数据 库 概述 





1.1.1 基本 要 求 


(1) 掌握 有 关 数 据 库 的 基本 概念 及 其 之 间 的 关系 ,如 数据 \ 信 息 数据 库 、 数 据 库 管理 系 
统 、 数 据 库 系统 和 SQL 语言 。 

(2) 掌握 有 关 数 据 库 的 基本 关系 理论 ,投影 选择 和 连接 的 内 涵 。 

G) 概念 模型 的 实体 、 属 性 、 联 系 、 主 键 \ 实 体 集 、 实 体型 的 基本 概念 和 含义 ,了 解 概 念 模 
型 的 表示 方法 。 了 解数 据 库 设计 中 关系 模型 的 规范 化 的 意义 。 

(4) 了 解 MySQL 数据 库 软件 的 特点 和 用 途 。 

(5) 熟练 掌握 MySQL 数据 库 软 件 的 下 载 ,安装 和 配置 过 程 。 

(6) 学 会 利用 客户 端 工 具 登 录 MySQL 数据 库 。 

CO 了 解 可 视 化 工具 MySQL Workbench 的 安装 和 使 用 方法 。 

(8) 积累 本 课程 的 常用 英文 词汇 。 


1.1.2 重点 与 难点 


1. 本 章 重 点 

(1) 数据 库 管 理 系统 的 功能 和 组 成 。 

COD 关系 数据 库 的 基本 理论 。 

(3) 数据 库 系 统 的 基本 组 成 。 

(4) 安装 .启动 和 配置 MySQL 的 基本 过 程 。 
(5) 利用 客户 端 工 具 登 录 MySQL 数据 库 。 
2. 本 章 难点 

A) MySQL 数据 库 软件 的 下 载 、 安 装 和 配置 过 程 。 
CD 利用 客户 端 工具 登录 MySQL 数据 库 。 
(3) 关系 模型 的 规范 化 设计 的 用 途 。 

(4) 概念 模型 的 表示 方法 E-R 图 的 实现 。 


1.2 习题 参考 答案 


1. 选择 题 
CD 数据 模型 的 3 要 素 不 包括 $ 
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A. 数据 结构 B. 数据 操作 C. 数据 类 型 D. 完整 性 约束 
(2) 关系 运算 不 包括 

A. 连接 B. 投影 C. 选择 D. 查询 
(3) 主教 材 表 1-1 所 示 的 学 生 信息 表 中 的 主键 为 。 

A. studentno B. sex C. birthdate D. sname 
(4) 下 面 的 数据 库 产品 中 ， 是 开源 数据 库 。 

A. Oracle B. SQL Server C. MySQL D. DB2 
(5) E-R 概念 模型 中 ,信息 的 三 种 概念 单元 不 包括 

A. 实体 型 B. 实体 值 C. 实体 属性 D. 实体 间 联 系 
(6) Linux 和 UNIX 操作 平台 上 不 能 使 用 作为 数据 库 。 

A. Oracle B. DB2 C. MySQL D. SQL Server 
(7) E-R 图 是 数据 库 设 计 的 工具 之 一 ,一 般 适 用 于 建立 数据 库 的 。 

A. 概念 模型 B. 结构 模型 C. 物理 模型 D. 逻辑 模型 
(8) SQL 语言 又 称 

A. 结构 化 定义 语言 B. 结构 化 控制 语言 

C. 结构 化 查询 语言 D. 结构 化 操纵 语言 


(9) 从 E-R 模型 向 关系 模型 转换 ,一 个 M:N 的 联系 转换 成 一 个 关系 模式 时 ,该 关系 
模式 的 键 是 
A. M 端 实体 的 键 B. N 端 实体 的 键 
C. M 端 实体 键 与 N 端 实体 键 的 组 合 D. 重新 选取 其 他 属性 
(10) DB,DBS 和 DBMS 3 者 之 间 的 关系 是 
A. DB 包括 DBMS 和 DBS B. DBS 包括 DB 和 DBMS 
C. DBMS 包括 DB 和 DBS D. 不 能 相互 包括 





本 题 答 案 : CD ACBDACCB 











2. 简 答题 

(1) 什么 是 数据 库 管理 系统 ? 举 出 日 常生 活 中 一 些 应 用 数据 库 的 实际 范例 。 

答 : 数据 库 管 理 系 统 DBMS 是 位 于 用 户 和 操作 系统 之 间 的 一 种 操纵 和 管理 数据 库 的 
软件 ,用 于 建立 \ 使 用 和 维护 数据 库 。 它 对 数据 库 进行 统一 的 管理 和 控制 ,以 保证 数据 库 的 
安全 性 和 完整 性 ,是 数据 库 系统 的 核心 。 

日 常生 活 中 , 像 学 生 信息 管理 ,网 上 购物 银行 存 取 款 、 购 买 火车 票 等 ,其 软件 的 后 台 都 
是 由 数据 库 作为 支撑 的 。 

(2) 说 明 MySQL 数据 库 管 理 系 统 基 本 系统 架构 拥有 哪 4 大 模块 。 

答 : 数据 库 管理 系统 是 由 多 种 不 同 的 程序 模块 组 成 的 ,基本 数据 库 管 理 系统 的 系统 架 
构 一 般 包 括 如 下 4 部 分 功能 模块 : 

(D 存储 管理 (Storage Manager)。 数 据 库 管理 系统 通常 会 自行 配置 磁盘 空间 ,将 数据 
存 入 存储 装置 的 数据 库 。 

© 查询 处 理 (Query Processor)。 负 责 处 理 用 户 下 达 的 查询 语言 命令 语句 ,可 以 再 细 分 


成 多 个 模块 负责 检查 语法 ,优化 查询 命令 的 处 理 程序 。 

© 事务 管理 (Transaction Manager)。 事 务 管理 主要 分 为 : 同名 的 事务 管理 子 系统 , 负 
责 处 理 数据 库 的 事务 ,保障 数据 库 商 业 事 务 的 操作 需要 一 并 执行 ; 锁定 管理 (Lock 
Manager) ,也 称 为 并 发 控制 管理 (Concurrency-Control Manager) 子 系统 ,负责 资源 锁定 。 

(D 恢复 管理 (Recovery Manager) 。 人 恢复 管理 主要 是 日 志 管 理 (Log Manager) 子 系统 ， 
负责 记录 数据 库 的 所 有 操作 ,包含 事务 日 志 , 以 便 同 名 的 恢复 管理 子 系统 能 够 执行 恢复 处 
理 , 恢 复数 据 库 系 统 存储 的 数据 到 指定 的 时 间 点 。 

(3) 举例 说 明 3 种 关系 运算 的 特点 。 

答 : 在 关系 中 访问 所 需 的 数据 时 ,需要 对 关系 进行 一 定 的 关系 运算 。 关 系数 据 库 主要 
支持 选择 .投影 和 连接 关系 运算 ,它们 源 于 关系 代数 中 并 \ 交 、 差 .选择 .投影 和 连接 等 运算 。 

(D 选择 关系 用 于 查找 符合 条 件 的 行 ,从 而 形成 新 关系 。 新 关系 和 原来 关系 结构 一 致 ， 
记录 行 变 少 。 例 如 在 学 生 表 中 查询 年 龄 18 岁 以 上 的 学 生 记 录 。 

@ 投影 关系 是 从 一 个 表 中 找 出 若干 字段 形成 一 个 新 关系 的 操作 ,新 关系 与 原来 关系 的 
记录 行 应 该 一 样 多 ,但 其 数据 列 变 少 。 例 如 在 学 生 表 中 输出 学 生 的 学 号 、 姓 名 和 出 生日 期 。 

O 连接 关系 是 从 两 个 表 中 选择 满足 条 件 的 记录 , 且 新 关系 中 包含 原来 多 个 关系 的 列 ， 
新 关系 结构 中 的 列 类 型 由 原来 关系 中 的 列 映射 而 来 。 例 如 ,查询 学 生 的 学 号 、 姓 名 和 期 末 成 
绩 。3 个 输出 项 并 不 是 在 一 个 表 中 可 以 搜索 到 ,需要 进行 连接 操作 。 即 将 2 个 或 多 个 表 中 
的 行 按 一 定 的 条 件 横向 结合 ,形成 一 个 新 的 临时 表 , 在 此 临时 表 中 进行 数据 查询 。 

3. 上 机 练习 

OD 从 MySQL 的 官方 网 站 (https://dev. mysql. com/downloads/) 下 载 MySQL 5. 7. 19 版 
本 的 数据 库 , 解 压缩 后 进行 安装 ,观察 安装 成 功 后 的 效果 。 

4. D 下 载 软件 。 登 录 MySQL 的 官方 网 站 (https://dev. mysql. com/downloads/)， 
在 该 网 站 上 访问 如 下 页 面 : https://dev. mysql. com/downloads/windows/installer/8. 0. 
html。 即 可 得 到 图 1-1 所 示 的 下 载 软件 版 本 mysql-installer-community-5. 7. 19. 0. msi。 单 
击 Download 按钮 , 即 可 下 载 MySQL 免费 软件 。 











| Generally Available (GA) Releases Development Releases 





MySQL Installer 5.7.19 


Select Operating System: Looking for previous GA 
[Microsoft Windows i versions? 
Windows (x86, 32-bit), MSI Installer 5.7.19 18.5M 
{mysql-installer-web-community-5.7.19.0.msi) MD5- 28e66ad90bbT9afa2el1583b6ad327a7 | Signature 
Windows (x86, 32-bit), MSI Installer 5719 378.8M 
(mysqL-installer-community-5.7 19.0.msi) MDS: 25T8b£c3c30213cee42dTT5835659665 | Signature 











图 1-1 MySQL 5. 7. 19 版 本 软件 
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Q 软件 安装 演示 。 双 击 下 载 软件 mysal-installerxcommunity-5. 7. 19. 0. msi, 进入 如 
图 1-2 所 示 的 开始 安装 界面 。 单 击 “ 运 行 ” 按 钮 ,进入 许可 协议 界面 License Agreement, 选 
F% I accept the licence terms 复 选 框 , 单 击 Next 按钮 .进入 如 图 1-3 所 示 的 选择 安装 类 型 界 
Wi Choosing a Setup Type, 选 择 安装 类 型 Full, 单 击 Next 按钮 ,进入 图 1-4 所 示 的 界面 。 单 
ih Execute 按钮 ,依次 进行 安装 即 可 。 在 实际 安装 过 程 中 ,要 注意 的 问题 包括 软件 环境 是 否 
合适 ,还 要 注意 记 住 设置 参数 ,如 密码 、 端 口号 等 。 


“op\mysql-installer-community-5.7.19.0.msi 
Oracle America. Inc. 

Windows Installer 程序 包 

CAUsers Administrator Desktop mysql-ins.... 


| 加 打开 此 文件 前 总 是 询问 mm) 


E a 








1-2 安全 警告 





[EJ MySQL Installer 


MySQL Installer Choosing a Setup Type 
Add munity 
Please select the Setup Type that suits your use case. 


© Developer Default Setup Type Description 
installs all products needed for [Installs all of the products available in this catalog 
MySQL development purposes. including MySQL Server, MySQL Shell, MySQL 
Router, MySQL Workbench, MySQL Connectors, 
: documentation, samples and examples and 
© Server only much more. 
Installs only the MySQL Server 
product. 


© Gent only 


Installs only the MySQL Client 
products, without a server. 


@ Ful 


Installs all included MySQL 
products and features. 


) Custom. 


Manually select the products that 
should be installed on the 
system 




















图 1-3 选择 安装 版 本 


@ 软件 配置 演示 。 右 击 “ 计 算 机 ?图 标 , 在 弹出 的 快捷 菜单 中 选择 “属性 ”命令 ,在 弹出 
的 “控制 面板 ”主页 中 单 击 “ 高 级 系统 设置 ”标签 ,对 话 框 中 选择 “高 级 系统 设置 ”, 弹 出 “系统 
属性 ”对 话 框 ,如 图 1-5 所 示 。 





MySQL Installer Check Requirements 


nmunity 


The following products have failing requirements. The installer will attempt to resolve some 


of this automatically. Requirements marked as manual cannot be resolved automatically. 
Click on those items to try and resolve them manually. 





For Product Requirement. 
O MySQL Server 5.7.19 Microsoft Visual C++ 2013 Runtime... 
O MySQL Utilities 1.6.5 Microsoft Visual C++ 2013 Runtime... 
O MySQL Shell 1.0.9 Microsoft Visual C++ 2013 Runtime... 
O MySQL Router 2.1.3 Microsoft Visual C++ 2015 Runtime... 
O Connector/ODBC 5.3.8 Microsoft Visual C++ 2013 Runtime... 
O Connector/C++ 1.1.9 Microsoft Visual C++ 2013 Runtime... 
O Connector/Python (3.4) 2.1.6 Python 3.4 is not installed 

O MySQL Connector/C 6.1.10 Microsoft Visual C++ 2015 Runtime... 
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图 1-5 “系统 属性 ”对 话 框 


CD 在 “系统 属性 ”对 话 框 中 ,打开 “高 级 ”选项 卡 , 单 击 “ 环 境 变量 ”按钮 ,弹出 “环境 变量 ” 
对 话 框 。 在 “环境 变量 ”对 话 框 中 ,定位 到 “系统 变量 ”中 的 path 选项 , 单 击 “ 编 辑 ” 按 钮 ,将 弹 
出 “编辑 系统 变量 ”对 话 框 ,如 图 1-6 所 示 。 在 “编辑 系统 变量 ”对 话 框 中 ,将 MySQL 服务 器 
的 bin 文件 夹 位置 (F:\Program Files\MySQL\MySQL Server 5. 7\bin) 添 加 到 变量 值 文 


yw 
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本 框 中 ,注意 要 使 用 *; ”与 其 他 变量 值 进行 分 隔 ,最 后 , 单 击 * 确 定 ” 按 钮 。 环 境 变量 设置 完成 
后 ,再 使 用 MySQL 命令 即 可 成 功 连接 MySQL 服务 器 。 
a 





















FEROD: path 
EBEV: ;VProgran Files\MySQL\HySQL Server €| 


[确证 )J( HÀ | 




























1-6 “编辑 系统 变量 ”对 话 框 


(2) 在 控制 台中 完成 操作 。 在 启动 MySQL 服务 后 打开 控制 台 , 在 控制 台中 输入 密码 
完成 MySQL 的 登录 ,并且 执行 select 命令 的 相关 语句 查看 系统 的 当前 日 期 。 

A. 主要 操作 命令 和 运行 结果 如 下 : 

C:\Users\Administrator > mysql -u root -p 


Enter password: ****** 
mysql» select curdate(); 


4------------ * 
| curdate() | 
4------------ * 
| 2017-05-01 | 
4------------ * 


1 row in set (0.07 sec) 


(3) 说 明 在 “服务 ”窗口 中 ,MySQL 服务 器 的 启动 和 关闭 方法 。 
答 : 执行 “开始 ”一 “运行 ”命令 ,输入 “services. msc” 后 按 Enter 键 ,也 可 以 弹出 图 1-7 所 
示 的 窗口 。 从 中 可 以 看 到 MySQL 服务 已 经 启动 ,而 且 服 务 的 启动 类 型 是 自动 启动 。 
[à me CO» ---^ "ew * $8 S0 Iii e] 


文件 (月 ”操作 (A) EEM 帮助 (H) | 
e€9lf(S:ss|Hm».nun | 
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MySQL57 zae “ Ft 。 状态 。 启动 类 型 登录 为 E 
E Ü} Microsoft iSCSIIni.. 38... 手动 本 地 系统 
qu. Ü} Microsoft Office D... 运行.。 手动 本 地 系统 
量 启 起 此 服务 & Microsoft Softwar.. 管理 手动 本 地 系统 
Č Multimedia Class .， 基 于 .。 BEM AM ae D 
E Net.Msmq Listene... Recei... TARS 
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Ti Network Access P... 网络.… 手动 网 络 服务 
扩展 人 标准 六 
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1-7 “服务 ”窗口 


选中 MySQL 服务 项 右 击 ,弹出 如 图 1-8 所 示 的 对 话 框 。 可 以 在 弹出 的 菜单 中 ,对 
MySQL57 服务 器 进行 “启动 “停止 “暂停 “恢复 "和 “重新 启动 ”等 操作 。 


det ”状态 启动 类型 ”登录 为 
. 已 启动 


G Office Source E. 保存- 








图 1-8 更 改 服务 的 启动 类 型 
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第 2 章 MySQL 语言 基础 





2.1.1 基本 要 求 


(1) 了 解 字符 集 和 字符 序 的 基本 概念 和 用 途 。 

(2) 掌握 标识 符 ,关键 字 、 常 量 、 变 量 等 MySQL 的 基本 语法 要 素 的 概念 和 应 用 。 

(3) 熟练 掌握 常用 字符 型 .数值 型 .日 期 时 间 型 等 数据 类 型 的 用 途 。 

(4) 熟练 掌握 算术 运算 符 、 比 较 运 算 符 、 人 逻辑 运算 符 及 位 运算 符 的 用 途 。 了 解 运算 符 的 
优先 级 及 其 作用 。 

(5) 熟练 掌握 常用 字符 型 函数 .日 期 时 间 型 函数 .数值 型 函数 的 格式 和 用 途 。 

(6) 掌握 各 种 值 类 型 表达 式 的 写法 和 用 途 。 

(7) 学 会 利用 select 语句 对 常量 .变量 函数、 表达 式 等 进行 数据 输出 的 操作 。 


2.1.2 重点 与 难点 


1. 本 章 重 点 

(1) 字符 集 和 字符 序 的 基本 概念 。 

(2) 标识 符 .关键 字 常量 .变量 等 MySQL 的 基本 语法 要 素 的 概念 和 应 用 。 
(3) 常用 字符 型 数值 型 .日 期 时 间 型 等 数据 类 型 的 用 途 。 

(4) 算术 运算 符 、 比 较 运算 符 、 人 逻辑 运算 符 及 位 运算 符 的 用 途 。 

(5) 常用 字符 型 函数 ,日 期 时 间 型 函数 、 数 值 型 函数 的 格式 和 用 途 。 

2. 本 章 难 点 

(1) 各 种 数据 类 型 的 变量 的 定义 和 使 用 方法 。 

(2) 常用 字符 型 函数 ,日 期 时 间 型 函数 ,数值 型 函数 的 格式 。 

G) 算术 运算 符 、 比 较 运 算 符 、 逻 辑 运算 符 的 使 用 方法 。 


2.2 习题 参考 答案 
1. 选择 题 


(OD 以 下 命令 中 ， 是 DML 语句 。 
A. create B. alter C. select D. drop 


(2) 以 下 关于 MySQL 的 说 法 中 错误 的 是 s 
A. MySQL 是 一 种 关系 型 数据 库 管理 系统 
B. MySQL 软件 是 一 种 开放 源码 软件 
C. MySQL 服务 器 工作 在 客户 端 /服务 器 模式 下 ,或 嵌入 式 系统 中 
D. 在 Windows 系统 下 MySQL 中 书写 MySQL 语句 区 分 大 小 写 


(3) 控制 台中 执行 语句 时 可 以 退出 MySQL. 
A. exlt B. go 或 quit C. go 或 exit D. exit zk quit 
(4) 关于 MySQL 数据 库 的 说 法 ,选项 的 说 法 是 错误 的 。 


A. MySQL 数据 库 不 仅 开放 源码 ,而 且 能 够 跨 平 台 使 用 。 例 如 ,可 以 在 Windows 
操作 系统 中 安装 MySQL 数据 库 , 也 可 以 在 Linux 操作 系统 中 使 用 MySQL 数 
据 库 

B. MySQL 数据 库 启动 服务 时 有 两 种 方式 ,如 果 服 务 已 经 启动 可 以 在 任务 管理 器 
中 查找 mysqlld. exe 程序 ,如 果 该 进程 存在 则 表示 正在 运行 


C. 手动 更 改 MySQL 的 配置 文件 my. ini 时 ,只 能 更 改 与 客户 端 有 关 的 配置 ,而 不 
能 更 改 与 服务 器 端 相 关 的 配置 信息 
D. 登录 MySQL 数据 库 成 功 后 ,直接 输入 “help;” 语 句 后 , 按 Enter 键 可 以 查看 帮 
助 信息 
(5) 下 列 类 型 不 是 MySQL 中 常用 的 数据 类 型 。 
A. int B. var C. time D. char 
(6) 在 MySQL 中 会 话 变量 前 面 的 字符 为 。 
A. 空格 B. # C. @@ D. @ 
CO 设置 表 的 默认 字符 集 关键 字 是 。 
A. default character B. default set 
C. default D. default character set 











本 题 答 案 : CD DCB D D 





2. 简 答题 

CD 简 述 字符 集 UTF-8 和 GB 2312 的 区 别 。 

答 : UTF-8 被 称 为 通用 转换 格式 ,是 针对 Unicode 字符 的 一 种 变 长 字符 编码 。 该 字符 
集 是 用 以 解决 国际 上 字符 的 一 种 多 字 节 编码 , 它 对 英文 使 用 8B. 中文 使 用 24B 来 编码 。 
UTF-8 包含 全 世界 所 有 国家 需要 用 到 的 字符 ,是 国际 编码 ,通用 性 强 。UTF-8 编码 的 文字 
可 以 在 各 国 支 持 UTF-8 字符 集 的 浏览 器 上 显示 。 

GB 2312 是 简体 中 文字 符 集 ,GBK 是 对 GB 2312 的 扩展 ,GBK 是 在 国家 标准 GB 2312 
基础 上 扩容 后 兼容 GB 2312 的 标准 。GBK 的 文字 编码 是 用 双 字 节 来 表示 的 , 即 不 论 中 英文 
字符 均 使 用 双 字 节 来 表示 ,为 了 区 分 中 文 , 将 其 最 高 位 都 设 定 成 1。GBK 包含 全 部 中 文字 
符 ,是 国家 编码 ,通用 性 比 UTF-8 差 , 不 过 UTF-8 占用 的 数据 库 比 GBK K. 


第 
(2) datetime 类 型 和 timestamp 类 型 的 相同 点 和 不 同 点 是 什么 ? 1 
75. 日 期 与 时 间 类 型 是 为 了 方便 在 数据 库 中 存储 日 期 和 时 间 而 设计 的 , datetime 和 部 
分 
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timestamp 表示 日 期 和 时 间 。 其 中 的 每 种 类 型 都 有 其 取 值 的 范围 ,如 赋予 它 一 个 不 合法 的 
值 ,将 会 被 “0” 代 蔡 。datetime 的 取 值 范围 为 1000-01-01 00:00:00 — 9999-12-31 23:59:59. 
而 timestamp 的 取 值 范围 是 1970-01-01 00:00:00 至 2037 年 的 某 个 时 间 。 

(3) MySQL 支持 的 数据 类 型 主要 有 哪 几 类 ? 17 属于 什么 类 型 ?'17' 属 于 什么 类 型 ? 

答 : MySQL 支持 的 数据 类 型 主要 包括 数值 型 .字符 型 和 日 期 时 间 型 等 。17 属于 数值 
型 中 的 整 型 数据 ,'17' 属 于 字符 型 数据 。 

(4) 简 述 系统 变量 .全 局 变量 和 会 话 变量 的 关系 。 

E, 系统 变量 包括 全 局 系统 变量 和 会 话 系统 变量 两 种 类 型 。 

全 局 变量 在 MySQL 启动 时 由 服务 器 自动 将 它们 初始 化 为 默认 值 , 主 要 影响 整个 
MySQL 实例 的 全 局 设置 ,大 部 分 全 局 变量 都 是 作为 MySQL 的 服务 器 调节 参数 存在 。 对 全 
局 变量 的 修改 会 影响 到 整个 服务 器 。 

会 话 变量 在 每 次 建立 一 个 新 的 连接 时 ,由 MySQL 来 初始 化 。 对 会 话 变量 的 修改 ,只 会 
影响 到 当前 的 会 话 ,也 就 是 当前 的 数据 库 连 接 。 会 话 变量 可 以 随时 定义 ,必须 在 名 称 前 加 @ 
符号 。 

(5) 简 述 聚合 函数 的 特点 和 用 途 。 

答 : 聚合 函数 用 于 对 一 组 值 进行 计算 并 返回 一 个 单一 的 值 。 除 count 函数 之 外 ,其 他 
聚合 函数 忽略 空 值 。 聚 合 函 数 经 常 与 select 语句 的 group by 子 句 一 同 使 用 。 聚 合 函数 的 
作用 是 在 结果 集中 通过 对 被 选 列 值 的 收集 处 理 , 并 返回 一 个 数值 型 的 计算 结果 。 

3. 上 机 练习 

(1) 创建 文本 文件 。 将 查询 系统 当前 日 期 .当前 时 间 以 及 到 2019 年 1 月 1 号 还 有 多 少 
天 。 然 后 通过 MySQL 命令 执行 文本 文件 中 的 内 容 。 

答 : 在 文本 文件 “d:\ my231. txt" 中 的 内 容 如 下 : 


select now() ; -- 查询 当前 日 期 命令 

select curtime( ); =-- 输出 当前 时 间 

select datediff('2019 - 1 - 1',now()); -- 到 2019 年 1 月 1 号 的 天 数 

在 DOS 窗口 中 执行 MySQL 命令 语句 ,指定 文本 文件 并 执行 该 文件 中 的 语句 。 
输出 结果 如 下 : 


C:\Users\Administrator > mysql < D:\my231. txt -u root -p 
Enter password: ****** 

now( ) 

2017 — 08 - 22 09:03:53 

curtime() 

09:03:53 

datediff('2019 - 1 - 1',now()) 

497 

C:\Users\Administrator > 


(2) 利用 随机 函数 输出 20 一 90 的 任意 两 个 数 ( 含 2 位 小 数 ) 。 
答 : 命令 和 运行 结果 如 下 : 


mysql» select 20+ round(70 * rand(),2) , 20+ round(70 * rand(),2); 
4---------------------- + 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 


| 20+ round(70 * rand(),2) | 20+ round(70 * rand(),2) | 


1 row in set (0.02 sec) 


(3) 计算 1000 天 后 的 日 期 和 3000 分 钟 后 的 日 期 时 间 。 
答 : 命令 和 运行 结果 如 下 : 


mysql» select date add(now(), interval 1000 day); 


————— ÁÁá + 
| date add(now(), interval 1000 day) | 
——————MÁ 4 
| 2020 - 03 - 29 19:29:22 | 

————— + 


1 row in set (0.00 sec) 


mysql > select date add(now(), interval 3000 minute); 


二 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 
| date_add(now( ), interval 3000 minute) | 
二 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 
| 2017 - 07 - 05 21:29:22 | 
4-----------------2------------- * 


1 row in set (0.00 sec) 
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第 3 章 MySQL 数据 库 的 基本 操作 





3.1.1 基本 要 求 


(1) 了 解数 据 库 设 计 的 基本 过 程 。 

(2) 掌握 概念 模型 的 设计 过 程 和 利用 E-R 图 描述 概念 模型 的 方法 。 
(3) 了 解 常 用 MySQL 数据 库 的 用 途 。 

(4) 了 解 常用 MySQL 数据 库存 储 引擎 的 特点 。 

(5) 掌握 设置 和 修改 MySQL 数据 库存 储 引擎 的 操作 。 

(6) 掌握 MySQL 数据 库 的 创建 ,打开 和 存储 方法 。 

(7) 学 会 利用 MySQL Workbench 可 视 化 软件 维护 数据 库 。 


3.1.2 重点 与 难点 


1. 本 章 重 点 

(1) 概念 模型 的 设计 过 程 。 

(2) 利用 E-R 图 描述 概念 模型 的 方法 。 

(3) 设置 和 修改 MySQL 数据 库存 储 引 擎 的 操作 。 

(4) 掌握 MySQL 数据 库 的 创建 打开、 删除 和 存储 方法 。 

(5) 利用 MySQL Workbench 可 视 化 软件 维护 数据 库 的 基本 操作 。 
2. 本 章 难 点 

COD 概念 模型 的 设计 过 程 。 

(2) 利用 E-R 图 描述 概念 模型 的 方法 。 

(3) 利用 MySQL Workbench 可 视 化 软件 维护 数据 库 的 基本 操作 。 


3.2 习题 参考 答案 





1. 选择 题 
(D 在 MySQL 数据 库 中 ,通常 使 用 语句 来 指定 一 个 已 有 数据 库 作 为 当前 工 
作 数 据 库 。 


A. using B. used C. uses D. use 


(2) 命令 用 于 删除 一 个 数据 库 。 


A. create database B. drop database 
C. alter database D. use InnoDB 
(3) 存储 引擎 支持 外 键 (Foreign Key) 和 事务 (Transaction) 和 全 文 检索 。 
A. MEMORY B. MyISAM C. InnoDB D. MySQL 
(4) 在 创建 数据 库 时 ,可 以 使 用 子 句 确保 如 果 数 据 库 不 存在 就 创建 它 , 如 果 存 
在 就 直接 使 用 它 。 
A. if not exists B. if exists C. if not exist D. if exist 


G) 在 图 形 管理 工具 MySQL WorkBench 窗口 中 使 用 可 视 化 的 界面 不 能 够 支 





持 
A. 数据 库 引 擎 开发 ”B. 创建 数据 库 C. 维护 数据 库 D. 数据 库 设计 
(6) MySQL 自 带 数据 库 中 ， 存储 了 系统 的 权限 信息 。 
A. information schema B. mysql 
C. sakila D. performance schema 





本 题 答案 :DBCA AB 











2. 简 答题 

(1) 如 何在 MySQL Workbench 窗口 中 修改 数据 库 的 字符 集 ? 

4& . 连接 MySQL Workbench 软件 后 ,在 SCHEMAS 区 选择 数据 库 ,例如 mysqltest， 
Hiti mysqltest 数据 库 , 如 图 3-1 所 示 , 执 行 Alter Schema 命令 ,进入 如 图 3-2 所 示 的 数据 库 
修改 界面 ,选择 Collation 字符 集 选项 即 可 。 

(2) 简 述 在 MySQL Workbench 窗口 中 创建 数据 库 的 步骤 。 

答 : MySQL Workbench 窗口 中 使 用 可 视 化 的 界面 可 以 创建 数据 库 。 使 用 MySQL 
Workbench 创建 数据 库 的 步骤 如 下 : 

(D 进入 MySQL Workbench 主 界面 进行 MySQL 数据 库 的 连接 。 进 入 MySQL 
Workbench 数据 库 操作 的 主 界面 , 单 击 如 图 3-2 所 示 的 提示 创建 数据 库 命令 。 


SCHEMAS eo 
Q Filter objects 














Set as Default Schena H 
Filter to This Schema 
Schema Inspector 

Copy to Clipboard p 
Send to SQL Editor » 


一 一 一 一 一 latin5 -latinS turkish ci 
Create Schema... latin5 - latin5 bin. 




















armsci8 - default colation 
Alter Schema... o ad 
i8 - armsci bin 
en utfa - default colation 
utf8 - utf8 bin 
Search Table Data... uta ey id E 
utfa -utf8 danish à 
edu utfs -utf8 esperanto ci 1 
图 3-1 选择 数据 库 图 3-2 选择 字符 集 部 
z 
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@ 进入 设置 数据 库 参 数 界面 。 输 入 数据 库 名 ,选择 字符 集 和 排序 规则 ,再 单 击 Apply 
按钮 。 

C) 进入 创建 数据 库 脚 本 显示 对 话 框 ,再 单 击 Apply 按钮 , 即 可 完成 数据 库 的 创建 。 

@ 在 数据 库 操作 界面 (图 3-3) 的 schemas 区 域 ,就 可 以 看 到 刚才 创建 的 数据 库 
mysqltest, 还 有 前 面 创 建 的 数据 库 teaching 以 及 MySQL 中 的 系统 数据 库 了 。 
(3) 简 述 MySQL 数据 库 的 特点 。 

















A t 答 : MySQL 与 其 他 的 大 型 数据 库 例如 Oracle, 
»H FRR DB2,SQL Server 等 相 比 功能 稍 弱 一 些 , 其 主要 有 以 下 
Filter to This Schema 特点 H 
cc 。 具 有 强大 的 数据 保护 功能 ,可 以 处 理 拥有 万 亿 
SR OE E 条 记录 的 海量 数据 。 
Create Schema.. 。 支持 常见 的 SQL 语句 规范 。 
CHI T 。 可 移植 性 高 ,安装 简单 。 
。 具 有 良好 的 运行 效率 ,有 丰富 信息 的 网 络 支持 。 
eum 。 相 对 其 他 大 型 数据 库 , 调 试 . 管 理 , 优 化 简单 。 











可 移植 性 、 可 扩展 性 和 高 灵活 性 。 
提供 用 于 管理 检查、 优化 数据 库 操作 的 管理 
工具 。 

(4) 存储 引擎 InnoDB、MyISAM 和 MEMORY 各 有 什么 优 缺 点 ? 

答 : MySQL 数据 库 提供 了 多 种 存储 引擎 ,用 户 可 以 根据 不 同 的 需求 为 数据 表 选 择 不 同 
的 存储 引擎 。MySQL 5. 7 选择 InnoDB 作为 默认 存储 引擎 。InnoDB 是 事务 型 数据 库 的 首 
选 引擎 ,是 具有 提交 、 回 深 和 崩溃 恢复 能 力 的 事务 安全 存储 引擎 ,支持 行 锁定 和 外 键 约束 。 

InnoDB 是 MySQL 上 第 一 个 提供 外 键 约束 的 表 引 擎 ,而 且 InnoDB 对 事务 处 理 的 能 
力 , 也 是 MySQL 其 他 存储 引擎 所 无 法 与 之 比拟 的 。 相 对 MEMORY 来 说 , 写 处 理 能 力 差 
些 , 且 会 占用 较 多 磁盘 空间 以 保留 数据 和 索引 。InnoDB 存储 引擎 中 支持 自动 增长 列 auto 
increment , 

MEMORY 存储 引擎 是 MySQL 中 的 一 类 特殊 的 存储 引擎 。 其 使 用 存储 在 内 存 中 的 内 
容 来 创建 表 , 而 且 所 有 数据 也 放 在 内 存 中 。 这 些 特性 都 与 InnoDB 存储 引擎 .MyISAM 存储 
引擎 不 同 。 

MyISAM 存储 引擎 曾 是 MySQL 的 默认 存储 引擎 。MyISAM 存储 引擎 不 支持 事务 、 外 
键 约束 ,但 访问 速度 快 ,对 事务 完整 性 不 要 求 , 适 合 于 以 select/insert 为 主 的 表 。 

现在 的 MyISAM 增加 了 很 多 有 用 的 扩展 。MyISAM 存储 引擎 的 表 存储 成 三 个 文件 。 

3. 上 机 练习 题 

题目 要 求 : 登录 数据 库 系 统 以 后 ,分别 创建 student 和 teacher 数据 库 ,数据 库 都 创建 成 
功 后 ,删除 teacher 数据 库 。 然 后 查看 数据 库 系 统 中 还 存在 哪些 数据 库 。 

主要 实现 过 程 如 下 所 示 : 

(1) 登录 MySQL 数据 库 客 户 端 ; 

(2) 查看 数据 库 系统 中 已 存在 的 数据 库 ; 

(3) 查看 该 数据 库 系 统 支 持 的 存储 引擎 的 类 型 ; 


3-3 数据 库 操作 主 界面 


(4). 8/2 student 数据 库 和 teacher 数据 库 ; 

(5) 再 次 查看 数据 库 系统 中 已 经 存在 的 数据 库 , 确 保 student 和 teacher 数据 库 已 经 
存在 ; 

(6) 删除 teacher 数据 库 ; 

CD 再 次 查看 数据 库 系统 中 已 经 存在 的 数据 库 ,确保 teacher 数据 库 已 经 删除 。 

答 : 命令 和 运行 结果 分 别 显示 如 下 : 

(1) C:\Users\Administrator > mysql -u root -P 

Enter password: ssxxx« 
(2) mysql» show databases; 


information schema l 
db_examsystem | 
mysql | 
mysqltest | 
performance schema | 
sakila | 
sys | 
teaching | 

| 





world 
m 





9 rows in set (0.17 sec) 
(3) mysql > show engines; -- 结果 参看 教材 第 3.5.1 小 节 


(4) mysql» create database if not exists teacher; 
Query OK, 1 row affected (0.07 sec) 

mysql» create database if not exists student; 
Query OK, 1 row affected (0.02 sec) 


(5) mysql» show databases; 


information schema | 
db examsystem | 
mysql | 
mysqltest | 
performance schema | 
sakila | 
student | 
sys | 
teacher | 

l 

| 





$ 
" 
I] 
a. 


11 rows in set (0.00 sec) 


(6) mysql > drop database teacher; 
Query OK, 0 rows affected (0.28 sec) 


Yy4-—w 
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(7) mysql» show databases; 


information schema | 
db examsystem | 
mysql | 
mysqltest | 
performance schema | 
sakila l 
student | 
sys | 
teaching | 
| 
* 





world 


+ 





10 rows in set (0.00 sec) 





第 4 章 表 及 数据 完整 性 





4.1.1 基本 要 求 


(1) 了 解 InnoDB 存储 引擎 表 空间 的 基本 概念 。 

(2) 掌握 创建 数据 库 表 的 命令 格式 ,以 及 表 中 各 字段 的 数据 类 型 和 取 值 范围 。 

(3) 熟练 掌握 数据 表 的 创建 、 查 看 、 修 改 和 删除 等 操作 。 

(4) 熟练 掌握 数据 表 记 录 的 添加 、 修 改 和 删除 操作 。 

(5) 掌握 利用 MySQL Workbench 管理 表 的 基本 过 程 。 

(6) 了 解 表 的 数据 完整 性 的 用 途 。 

(7) 掌握 数据 表 的 各 种 约束 的 创建 和 管理 操作 。 了 解 表 的 数据 完整 性 规则 与 数据 的 正 
确 性 、 精 确 性 和 可 靠 性 的 关系 。 

(8) 了 解 临时 表 的 用 途 和 管理 操作 。 


4.1.2 重点 与 难点 


1. 本 章 重 点 

(1) 创建 数据 库 表 的 命令 格式 。 

(2) 数据 表 的 创建 .查看 ,修改 和 删除 等 操作 。 
(3) 表 记 录 的 添加 、 修 改 和 删除 操作 。 

(4) 掌握 利用 MySQL Workbench 管理 表 的 基本 过 程 。 
(5) 掌握 数据 表 的 各 种 约束 的 创建 和 管理 操作 。 
2. 本 章 难 点 

CD 创建 数据 库 表 的 命令 格式 。 

(2) 数据 表 的 创建 查看 ,修改 和 删除 等 操作 。 
G) 表 的 数据 完整 性 的 用 途 。 

(4) 数据 表 的 各 种 约束 的 创建 和 管理 操作 。 


4.2 习题 参考 答案 


1. 选择 题 
(1) 要 快速 完全 清空 一 张 表 中 的 记录 可 使 用 如 下 语句 


MySQL 数据 库 应 用 与 开发 习题 解答 与 上 才 指 时 





A. truncate table B. delete table 

C. drop table D. clear table 
(2) 使 用 insert 命令 插入 记录 时 ,使 用 关键 字 会 忽略 导致 重复 关键 字 的 错误 

记录 。 

A. no same B. ignore C. repeat D. unique 
(3) SQL 语句 中 修改 表 结 构 的 命令 是 É 

A. modify table B. modify structure 

C. alter table D. alter structure 
(4) 只 修改 列 的 数据 类 型 的 指令 是 

A. alter table ... alter column B. alter table ... modify column... 

C. alter table ... update ... D. alter table ... update column... 
C5) 删除 列 的 命令 是 

A. alter table ... delete... B. alter table ... delete column... 

C. alter table ... drop ... D. alter table ... drop column... 
(6) 创建 表 时 ,不 允许 某 列 为 空 可 以 使 用 命令 。 

A. not null B. no null C. not blank D. no blank 
C) WF 指令 无 法 增加 记录 。 

A. insert into ... values ... B. insert into ... select... 

C. insert into ... set ... D. insert into ... update... 
(8) 关于 truncate table 描述 不 正确 的 是 o 

A. truncate 将 删除 表 中 的 所 有 数据 

B. 表 中 包含 auto. increment 列 ,使 用 truncate table 可 以 重 置 序列 值 为 该 列 初 

始 值 

C. truncate 操作 比 delete 操作 占用 资源 多 

D. truncate table 删除 表 , 然 后 重新 构建 表 
(9) 在 创建 表 时 ,可 以 使 用 关键 字 使 当前 建立 的 表 为 临时 表 。 

A. ignore B. temporary C. temptable D. truncate 
(10) 下 列 描述 正确 的 是 


A. 一 个 数据 库 只 能 包含 一 个 数据 表 B. 一 个 数据 库 可 以 包含 多 个 数据 表 
C. 一 个 数据 库 只 能 包含 两 个 数据 表 D. 一 个 数据 表 可 以 包含 多 个 数据 库 








本 题 答案 : ABCBDADCBB 








间 。 


2. 简 答题 

(1) 简 述 在 创建 表 结 构 时 ,常用 哪些 数据 类 型 ? 其 主要 功能 是 什么 ? 

答 : 在 创建 MySQL 表 结 构 时 ,常用 的 4 类 标准 数据 类 型 的 主要 作用 是 : 

(D 字符 串 类 型 用 于 存储 普通 文本 值 或 特殊 类 型 set 和 enum 类 型 。 

© datetime 数据 类 型 存储 日 期 和 时 间 ,date 数据 类 型 存储 日 期 ,time 数据 类 型 存储 时 
Timestamp 存储 时 间 标 签 ,year 用 于 存储 年 份 。 


O 数字 类 型 包括 整数 类 型 和 浮 点 类 型 ,整数 类 型 是 数据 库 中 最 基本 的 数据 类 型 ,用 于 
存储 各 种 数值 范围 的 整数 。 浮 点 类 型 用 于 存储 定点 小 数 或 近似 数字 数据 类 型 。 

© 二 进 制 类 型 是 在 数据 库 中 存储 二 进 制 数 据 的 数据 类 型 。 

(2) 简 述 创建 表 时 各 类 约束 对 表 中 数据 的 作用 。 

答 : 在 定义 表 结 构 时 ,还 可 以 定义 与 该 表 相 关 的 完整 性 约束 条 件 , 包 括 实 体 完 整 性 、 参 
照 完整 性 和 用 户 自 定义 完整 性 。 这 些 约束 条 件 主要 包括 not null GESAR) , primary key 
(主键 约束 ) .unique( 唯 一 性 约束 ) , foreign key( 外 键 参照 完整 性 约束 ) 以 及 check (检查 约 
东 )。 各 种 约束 对 表 中 数据 的 作用 是 : 

CD 检查 约束 限制 一 列 的 允许 值 。 

Q 非 空 约束 限制 在 表 的 一 个 列 中 必须 输入 一 个 值 。 

© 唯一 约束 确保 一 列 或 列 的 组 合 没有 重复 值 。 

CD 主键 确保 一 个 表 中 的 每 一 行 可 以 被 指定 列 或 指定 列 的 组 合 唯一 地 标识 。 一 个 表 只 
能 有 一 个 主键 ,但 可 以 创建 多 个 唯一 约束 。 

© 外 键 强制 一 个 列 只 能 取 一 个 被 引用 的 表 中 存在 的 值 。 

(3) MySQL 支持 的 数据 完整 性 有 哪 几 类 ? 各 有 什么 作用 ? 

答 : 数据 完整 性 可 以 根据 其 作用 的 数据 库 对 象 和 范围 不 同 分 为 4 类 。 具 体内 容 包括 ， 

(D 域 完 整 性 。 要 求 列 的 数值 具有 正确 的 类 型 .格式 和 有 效 值 范围 ,并 确定 是 否 允 许 有 
空 值 。 通 常 使 用 有 效 性 检查 强制 域 完整 性 ,也 可 以 通过 限定 列 中 允许 的 数据 类 型 格式 或 有 
效 值 范围 来 强制 数据 完整 性 。 

O 实体 完整 性 。 要 求 表 中 的 每 一 行 具 有 唯一 的 标识 。 在 数据 库 中 ,如 student 表 中 的 
列 studentno 被 设 为 主键 , 则 会 保证 每 个 学 生 只 有 一 个 学 号 ,而 且 是 唯一 的 。 

O 引用 完整 性 。 指 两 个 表 的 主键 与 外 键 之 间 定 义 的 数据 完整 性 ,将 确保 主键 和 外 键 的 
关系 。 引 用 完整 性 可 以 保证 两 个 引用 表 间 的 数据 的 一 致 性 。 

CD 用 户 定义 完整 性 。 用 户 可 以 根据 其 应 用 环境 的 不 同 , 对 数据 库 设置 一 些 特殊 的 约束 
条 件 , 反 映 某 一 具体 应 用 所 涉及 的 数据 必须 满足 的 语句 要 求 。 用 户 定义 完整 性 的 实现 机 制 
有 规则 (Rule) 、 触 发 器 (Trigger) 和 存储 过 程 (Stored Procedure) 及 创建 数据 表 时 的 所 有 约 
W (Constraint). 

(D 简 述 在 MySQL Workbench 中 创建 含有 主键 的 表 的 步骤 。 

答 : 创建 MySQL 数据 表 , 可 以 利用 MySQL. Workbench 实现 可 视 化 方式 。 下 面 介 绍 
利用 可 视 化 方式 创建 表 的 过 程 。 

(D 打开 MySQL Workbench 工具 ,在 Schemas 区 域 找到 数据 库 列 表 。 

© 选择 一 个 数据 库 为 当前 数据 库 , 右 击 该 数据 库 , 在 弹出 的 菜单 中 执行 Set as Default 
Schema 命令 ,该 数据 库 就 变 成 当前 数据 库 。 

© 选择 Tables 选项 并 右 击 ,在 弹出 的 菜单 中 执行 Create Table 命令 。 进 入 数据 表 创 
建 初始 界面 。 

@ 输入 数据 库 表 名 ,选择 默认 数据 库 引擎 InnoDB, 参 照 设 计 好 的 表 结 构 , 分 别 输入 列 
名 ,选择 数据 类 型 ,输入 不 同类 型 的 参数 或 默认 值 。 

© 单 击 Apply 按钮 ,进入 脚本 审核 对 话 框 。 单 击 Show Logs 按钮 ,可 以 进一步 查看 脚 
本 。 单 击 Finish 按钮 ,完成 数据 表 的 创建 。 
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(5) 简 述 在 MySQL Workbench 中 修改 表 数 据 的 步骤 。 

75: . 数据 表 创 建成 功 后 ,就 可 以 实现 对 数据 表 结 构 进 行 修改 .删除 等 操作 ,也 可 以 编辑 、 
查询 和 添加 数据 。 

CD 选择 一 个 表 , 执 行 Select Rows-Limit 1000 命令 ,就 可 以 进入 查询 窗 体 。 在 该 窗 体 
中 ,不 但 可 以 进行 数据 添加 ,还 可 以 执行 查询 ,复制 数据 操作 ,也 可 以 修改 表 结 构 和 删除 表格 
等 操作 。 读 者 可 以 对 相关 工具 栏 按钮 进行 数据 的 添加 删除 操作 。 

© 单 击 Apply 按钮 后 ,再 单 击 Show Logs 按钮 ,可 以 进一步 查看 插入 数据 的 脚本 。 

© 单 击 Finish 按钮 ,完成 数据 表 数 据 的 输入 过 程 。 

同样 ,应 用 可 视 化 MySQL. Workbench 工具 可 以 对 数据 表 进 行 利 用 命令 实现 添加 、 删 
除 、 修 改 和 查询 等 各 种 操作 。 

3. 上 机 练习 题 

(1) 创建 booksmgt 数据 库 ,在 booksmgt 数据 库 中 使 用 MySQL 语句 创建 表 book 和 表 
author, 结 构 如 下 : 


book(bookid char(6),bookname varchar(30), price float(5,2)) 
author(authorid char(6), authorname varchar(10), bookid char(6), phone varchar(15)) 


设置 book 中 的 bookid 为 主键 ,author 表 中 的 bookid 为 外 键 。 
答 : (D 创建 表 book 的 MySQL 语句 : 


mysql > create database booksmgt; 
Query OK, 1 row affected (0.19 sec) 
mysql» use booksmgt; 
Database changed 
mysql» create table book ( 
-> bookid char(6) not null, 
一 > bookname varchar(30) null, 
-> price float(5, 2) null, 
一 > constraint PKbook primary key ( bookidasc ) 
=>); 
Query OK, 0 rows affected (0.78 sec) 


© 创建 表 author 的 MySQL 语句 : 


mysql > create table author( 
一 > anthor name nchar(4) not null, 
一 > bookid nchar(6) not null, 
-> address nchar(30) not null 
E 
Query OK, 0 rows affected (0.18 sec) 


© 设置 book 中 的 bookid 为 主键 ,author 表 中 的 bookid 为 外 键 : 


mysql > alter table author 
一 > add constraint FK book author 
—» foreign key(bookid) references book(bookid); 
Query OK, 0 rows affected (0.42 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


(2) 在 booksmgt 数据 库 中 利用 MySQL 语句 创建 一 个 图 书 销售 表 booksales 结构 如 
F: booksalesCbookid nchar(6) sellnum int. selldate datetime) 。 分 别 利用 insert, delete, 
update 请 句 添加 、 删 除 和 更 新 数据 。 

答 : CD 利用 MySQL 语句 创建 表 booksales 的 代码 。 


mysql» create table booksales( 
一 > bookid nchar(6) not null, 
一 > sellnum int not null, 
-> selldate datetime not null 
or 
Query OK, 0 rows affected (0.14 sec) 


© 利用 insert 语句 为 表 booksales 添加 数据 : 


mysql» Insert into booksales values ('m00011',7, '2016- 12- 20"); 
Query OK, 1 row affected (0.12 sec) 
mysql» Insert into booksales(bookid, sellnum, selldate) 
-> values ('m00018',3, '2016- 11- 16"); 
Query OK, 1 row affected (0.07 sec) 


© 利用 update 语句 为 表 booksales 更 新 数据 : 


mysql > update booksales set sellnum = 11 
一 > where bookid = 'm00011'; 
Query OK，1 row affected (0.09 sec) 


@ 利用 delete 语句 删除 表 booksales 的 数据 : 


mysql > delete from booksales 
-» where bookid = 'm00011'; 
Query OK, 1 row affected (0.08 sec) 


(3) 利用 MySQL 语句 先 删除 表 booksales 中 销售 时 间 在 2016 年 12 月 以 前 的 记录 ,再 
删除 全 部 记录 ,然后 删除 该 表 。 
答 : 利用 MySQL 语句 删除 表 booksales 数据 的 代码 如 下 : 


mysql» Delete from booksales 
一 > where selldate «'2016 - 12 - 01'; 
Query OK, 1 row affected (0.04 sec) 
mysql» truncate table booksales; -- 删除 所 有 数据 
Query OK，0 rows affected (0.16 sec) 


附 : 本 书 中 常用 的 数据 库 teaching 中 的 表 结构 和 表 记 录 。 
(1) 学 生 信息 表 student 


# student 表 结构 

create table if not exists student ( 

studentno char(11) not null comment '¥ 5 ', 
sname char(8) not null comment' 姓 名 '， 

sex enun( ' 男 '，' 女 ') default ' 男 ' comment PES", 
birthdate date not null comment'ih/E H Hj", 
entrance int(3) null comment' A ^ JR At", 
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phone varchar(12) not null comment iik ', 
Email varchar(20) not null comment' 电 子 信箱 …， 
primary key (studentno) 


) 


# student 表 常 用 数据 


studentno 

18122210009 
18122221324 
18125111109 
18125121107 
18135222201 
18137221508 
19111133071 
19112100072 
19112111208 
19122203567 
19123567897 
19126113307 


sname 

许 东 山 
何 白露 
敬 横 江 
— 
eA 
赵 临 江 
崔 依 歌 
宿 沧海 
韩 山川 
封 月 明 
赵 既 白 
梅 惟 江 


sex 


Xp X oxpoum dB xp Xp YR ON xbous 


(2) 课程 信息 表 course 


# course 表 结 构 
create table if not exists course ( 


courseno char(6) not null, 


cname char(6) not null, 


type char(8) not null, 


period int(2) not null, 
exp int(2) not null, 


term int(2) not null, 
primary key (courseno) 


); 


# course 表 常 用 数据 
Courseno cname 
c05103 ”电子 技术 
c05109 Cil 
c05127 数据 结构 
c05138 ”软件 工程 
c06108 ”机 械 制图 
c06127 ”机 械 设计 
c06172 ”铸造 工艺 
c08106 经济 法 
c08123 ”金融 学 
c08171 ”会 计 软 件 


G) 成 绩 信息 表 score 


# score 表 结 构 
create table if not exists score( 
studentno char(11) not null, 


courseno char(6) not null, 
daily float(3,1) default 0, 
final float(3,1) default 0, 


type 
必修 
必修 
必修 
选修 
必修 
必修 
选修 
必修 
必修 
选修 


birthdate 
1999/11/5 
2000/12/4 
2000/3/1 
1999/9/3 
2001/10/6 
2000/2/13 
2001/6/6 
2002/2/4 
2001/2/14 
2002/9/9 
2002/8/4 
2003/9/7 


entrance phone 


789 
879 
789 
737 
867 
789 
787 
658 
666 
898 
999 
787 


à 


o u-200€0wU0NMNMNM 


13623456778 
13178978999 
15678945623 
13145678921 
15978945645 
12367823453 
15556845645 
12545678998 
15878945612 
13245674564 
13175689345 
13245678543 


Email 
qwe(2163. com 
heyy@sina. com 
jing@ sina. com 
bing@126. com 
tang@163. com 
ping@163. com 
cui@126. com 
sul2@163. com 
han@163. com 
jiao@126. com 
pingan@163. com 
zhu@163. com 


primary key (studentno , courseno) 


) 


courseno daily 


# score 表 常 用 数据 
studentno 

18122210009 c05103 
18122210009 c05109 
18122221324 05103 
18122221324 c05109 
18125111109 c08106 
18125111109 c08123 
18125111109 c08171 
18125121107 05103 
18125121107 c05109 
18135222201 c05109 
18135222201 c08171 
18137221508 c08106 
18137221508 c08123 
18137221508 c08171 
19111133071 c05103 
19111133071 c05109 
19112100072 c05109 
19112100072 c06108 
19112111208 c05109 
19112111208 c06108 
19122111208 c06127 
19122203567 c05103 
19122203567 c05108 
19122203567 c06127 
19123567897 c05103 
19123567897 c06127 
19126113307 c06108 
19126113307 c08171 


87 
T 
88 
91 
79 
85 
Tu 
74 
89 
99 
95 
78 
78 
88 
82 
m 
87 
97 
85 
89 
78 
65 
88 
39 
85 
99 
66 
88 


(4) 教师 信息 表 teacher 
# teacher 表 结构 


create table if not exists teacher ( 
teacherno char(6) not null comment ' 教 师 编号 '， 


tname char(8) not null comment' 教 师 姓名 '， 


final 
82 
91 
62 
77 
99 
92 
92 
91 
62 
92 
82 
95 
89 
98 
69 
82 
86 
97 
91 
95 
67 
98 
89 
88 
了 3 
99 
82 
79 


major char(10) not null comment ' 专 业 '， 
prof char(10) not null comment ' 职 称 '， 


department char(16) not null comment ' 部 门 ', 
primary key (teacherno) 


); 


# teacher 表 常 用 数据 
teacherno tname 
05001 苏 超然 
t05002 常 杉 
t05003 WEE 
t05011 FRR 
t05017 EX: 


major 
软件 工程 
会 计 学 
网 络 安全 
软件 工程 
软件 测试 


prof 
教授 
助教 
教授 
副教授 
讲师 


department 
计算 机 学 院 
管理 学 院 

计算 机 学 院 
计算 机 学 院 
计算 机 学 院 
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t06011 夏 南 望 ”机械 制造 ”教授 机 械 学 院 
t06023 BEF 铸造 工艺 “副教授 ”材料 学 院 
t07019 韩 既 乐 ”经济 管理 ”讲师 管理 学 院 
t08017 时 观 金融 管理 ”副教授 ”管理 学 院 


(5) 纽带 表 teach_course 


# teach course 表 结 构 

create table if not exists teach course ( 
teacherno char(6) not null, 

courseno char(6) not null, 

primary key (teacherno, courseno) 

) 

# teach course 表 常 用 数据 


teacherno courseno 
t05001 c05109 
t05002 c05127 
t05003 c05127 
t05011 c05138 
t05017 c05127 
t06011 c06127 
t06023 c06172 
t07019 c08123 
t08017 c08106 


(6) 选课 信息 表 se course 


# se course 表 结 构 

create table se_course 

(sc, no int(6) not null auto increment, 

studentno char(11) not null, 

courseno char(6) not null, 

teacherno char(6) not null, 

sc time timestamp not null default now(), 

primary key (sc no) 

) 

# se_course 表 常 用 数据 

sc no Studentno  courseno teacherno score sc time 
1 19120000111 col236  t01237 NULL 2017 - 09 - 01 18:40:23 
2 19120000222  col237  t01239 NULL 2017 - 09 - 05 18:24:22 
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5.1.1 基本 要 求 


CO 了 解 选择 、 投 影 和 连接 的 基本 概念 。 

(2) 掌握 select 语句 的 基本 格式 和 各 个 子 句 的 格式 。 

(3) 掌握 单 表 查询 中 where ,group by、order by,having 和 limit 的 功能 。 

(4) 掌握 利用 group by 子 句 与 with rollup 选项 进行 统计 操作 时 ,各 个 聚合 函数 的 格 
式 ,功能 和 基本 应 用 。 

(5) 了 解 多 表 连 接 的 工作 过 程 ,掌握 4 种 多 表 连 接 的 格式 和 应 用 。 

(6) 了 解 子 查询 的 工作 过 程 和 应 用 场合 。 

(7) 掌握 子 查询 在 select, from 和 where 子 句 中 实现 的 操作 。 

(8) 掌握 利用 子 查询 成 批 添 加 、 删 除 和 修改 表 数 据 的 操作 方法 。 

(9) 掌握 使 用 正则 表达 式 进 行 模糊 查询 的 格式 和 方法 。 


5.1.[2 重点 与 难点 


1. 本 章 重 点 

(1) select 语句 的 基本 格式 和 各 个 子 句 的 格式 。 

(2) 单 表 查询 中 where、group by、order by、having 和 limit 各 子 句 的 功能 。 
(3) 聚合 函数 的 格式 、 功 能 和 基本 应 用 。 

(4) 内 连接 的 格式 和 基本 操作 。 

(5) 子 查询 在 select. from 和 where 子 句 中 实现 的 操作 。 

(6) 利用 子 查询 成 批 添加 、 删 除 和 修改 表 数 据 的 操作 方法 。 

(7) 使 用 正则 表达 式 进行 模糊 查询 的 格式 和 方法 。 

2. 本 章 难点 

CD 在 where 子 句 中 使 用 like、in、between 关键 字 时 的 各 种 操作 。 
(2) 利用 group by 子 句 与 with rollup 选项 进行 统计 操作 。 

(3) 外 连接 的 格式 和 应 用 场合 。 

(4) select 语句 中 使 用 子 查 询 时 的 技巧 。 

(5) 使 用 正则 表达 式 进行 模糊 查询 的 格式 和 方法 。 
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5.2 习题 参考 答案 





1. 选择 题 
CD select 语句 中 使 用 关键 字 可 以 将 重复 行 屏蔽 。 
A. order by B. having C. top D. distinct 
(2) 在 select 语句 中 ,可 以 使 用 子 句 ,将 结果 集中 的 数据 行 根据 选择 列 的 值 进 
行 逻辑 分 组 ,以 便 能 汇总 表 内 容 的 子 集 , 即 实现 对 每 个 组 的 聚集 计算 。 
A. limit B. group by C. where D. order by 
(3) 使 用 空 值 查询 时 ,表示 一 个 列 RR 不 是 空 值 的 表达 式 是 o 
A. RR is null B. RR = null C. RR <> null D. RR is not null 
(4) select * from city limit 5.10 描述 正确 的 是 
A. 获取 第 6 条 到 第 10 条 记录 B. 获取 第 5 条 到 第 10 条 记录 
C. 获取 第 6 条 到 第 15 条 记录 D. 获取 第 5 条 到 第 15 条 记录 
(5) select 语句 中 用 于 实现 关系 的 选择 运算 的 短语 是 E 
A. for B. while C. where D. condition 


(6) 关于 select 语句 以 下 哪 一 个 描述 是 错误 的 ? 
A. select 语句 用 于 查询 一 个 表 或 多 个 表 的 数据 
B. select 语句 属于 数据 操作 语言 (DML) 
C. select 语句 的 输出 列 必须 是 基于 表 的 列 
D. select 语句 表示 数据 库 中 一 组 特定 的 数据 记录 
(7) select 语句 的 执行 过 程 是 从 数据 库 中 选取 匹配 的 特定 记录 和 字段 ,并 将 这 些 数据 组 


织 成 一 个 结果 集 , 然 后 以 的 形式 返回 。 
A. 结构 体 数组 B. 系统 表 C. 永久 表 D. 临时 表 
(8) 现 有 订单 表 orders, 包 含 用 户 信息 userid, 产 品 信息 productid, 以 下 语句 


能 够 返回 至 少 被 订购 过 两 回 的 productid。 
A. select productid from orders where count(productid)> 1 
B. select productid from orders where max(productid)» 1 
C. select productid from orders where having count C productid) > 1 group 
by productid 


D. select productid from orders group by productid having count( productid) 1 





本 题 答案 :DBDCCCDD 











2. 思考 题 

d) 简 述 select 语句 的 各 个 子 句 的 作用 。 

Z, select 语句 是 SQL 语言 从 数据 库 中 获取 信息 的 一 个 基本 语句 ,其 各 子 句 的 作用 简 
述 如 下 : 

。 select 用 于 描述 结果 集 的 列 。 


from 用 于 指定 所 要 查询 数据 源 , 如 表 、 视 图 .表达 式 等 。 

where 用 于 定义 源 表 中 的 行 要 满足 select 语句 的 要 求 所 必须 达到 的 条 件 。 

group by 用 于 利用 对 查询 结构 的 指定 值 进行 分 组 统计 。 

having 子 句 是 应 用 于 分 组 结果 集 的 附加 条 件 。 

order by 用 于 对 查询 结果 进行 排序 。 

limit 用 于 限制 查询 的 输出 结果 行 。 使 用 limit 关键 字 来 限制 查询 结果 的 行 数 是 
MySQL 数据 库 的 特色 。 

(2) MySQL 中 通配符 与 正则 表达 式 的 区 别 是 什么 ? 

答 : 使 用 通配符 和 正则 表达 式 都 可 以 进行 模糊 查询 ,MySQL 中 有 两 种 通配符 :“%” 和 
下 面 线 “”。“%” 可 以 匹配 一 个 或 多 个 字符 ,可 以 代表 任意 长 度 的 字符 串 , 长 度 可 以 为 0; 
“_” 只 匹配 一 个 字符 。 一 般 在 查询 中 仅仅 用 于 简单 的 字符 串 匹 配 。 

正则 表达 式 通 常用 来 检索 或 替换 符合 某 个 模式 的 文本 内 容 , 根 据 指定 的 匹配 模式 匹配 
文本 中 符合 要 求 的 特殊 字符 串 。 例 如 从 一 个 文本 文件 中 提取 电话 号 码 , 查 找 一 篇 文章 中 重 
复 的 单词 或 者 替换 用 户 输入 的 某 些 词语 等 。 正 则 表达 式 强 大 而 且 灵 活 , 可 以 应 用 于 非常 复 
杂 的 查询 。 

(3) 说 明 在 select 语句 中 使 用 聚合 函数 应 该 注意 的 问题 。 

B: 聚合 函数 用 于 对 一 组 值 进行 计算 并 返回 一 个 单一 的 值 。 除 count. 函数 之 外 ,其 他 
聚合 函数 忽略 空 值 。 聚 合 函数 经 常 与 select 语句 的 group by 子 句 一 同 使 用 ,select 语句 的 
输出 项 中 只 能 包含 group by 子 句 分 组 列 和 聚合 函数 。 聚 合 函 数 的 作用 是 在 结果 集中 通过 
对 被 选 列 值 的 收集 处 理 ,返回 一 个 数值 型 的 计算 结果 。 

(4) 将 null 与 其 他 值 比较 会 产生 什么 结果 ? 数值 列 中 存在 null 会 产生 什么 结果 ? 

答 : MySQL 中 涉及 空 值 的 查询 用 null 来 表示 。null 不 同 于 数据 库 中 的 其 他 任何 值 。 
where 子 句 通常 会 返回 比较 的 计算 结果 为 真 的 行 。 为 了 取得 列 中 含有 null 的 行 , MySQL 
语句 包含 了 操作 符 功 能 is [not] null. 

一 个 字段 值 是 空 值 或 者 不 是 空 值 ,要 表示 为 “is null” 或 “is not null”。 不 能 表示 为 
“一 null" 或 “<> null”。 如 果 写 成 “字段 =null? 或 “字段 <> null”, 系 统 的 运行 结果 都 直接 处 理 
H null 值 ,按照 false 处 理 而 不 报错 。 

(5) 简 述 连接 查询 和 利用 union 语句 合并 结果 集 的 应 用 区 别 。 

答 : 连接 查询 是 通过 join 操作 将 多 个 表 按 照 指定 方式 连接 成 一 个 新 的 中 间 表 ,然后 再 
进行 查询 操作 。union 操作 是 将 多 个 select 语句 的 返回 结果 组 合 到 一 个 结果 集中 。 当 要 检 
索 的 数据 在 不 同 的 结果 集中 ,并 且 不 能 够 利用 一 个 单独 的 查询 语句 得 到 时 ,可 以 使 用 union 
合并 多 个 结果 集 。 将 两 个 或 更 多 查询 的 结果 合并 为 单个 结果 集 ,该 结果 集 包 含 联合 查询 中 
的 所 有 查询 的 全 部 行 。union 运算 不 同 于 使 用 连接 合并 两 个 表 中 的 列 的 运算 。 

(6) 什么 情况 下 使 用 limit 来 限制 查询 结果 的 数量 ? 

Z: 使 用 limit 关键 字 来 限制 查询 结果 的 条 数 是 MySQL 数据 库 的 特色 。 当 输出 结果 
中 的 记录 行 较 多 时 ,可 以 使 用 limit 子 句 将 符合 指定 范围 的 记录 行 过 滤 出 来 。 

3. 上 机 练习 题 (本 题 利用 teaching 数据 库 进 行 操作 ) 

CD 查询 course 表 中 的 所 有 记录 。 

7. 程序 代码 如 下 : 
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select * from course; 


(2) 查询 student 表 中 女生 的 人 数 。 
AR. 程序 代码 如 下 : 


select count( * ) from student 
where sex = ' 女 '; 


G) 查询 teacher 表 中 每 一 位 教授 的 教师 号 、 姓 名 和 专业 名 称 。 
答 : 代码 和 运行 结果 如 下 : 


mysql > select teacherno, tname, major from teacher 
一 > where prof = ' 教 授 '; 
+ 一 一 一 一 一 一 一 一 一 4------- 4------- * 


| teacherno | tname | major | 


| t05001 | 苏 超然 | 软件 工程 | 
| t05003 | 孙 释 安 | 网 络 安全 | 
| t06011 | 夏 南 望 | 机 械 制 造 | 
| t06027 | 陶 期 年 ”| 纳米 技术 | 


4 rows in set (0.15 sec) 


(4) 按 性 别 分 组 , 求 出 student 表 中 每 组 学 生 的 平均 年 龄 。 
答 : 代码 和 运行 结果 如 下 : 
mysql > select sex, avg( year(now()) - year(birthdate)) 


一 > from student 
一 > group by sex; 


+----+---------------------------- + 
| sex | avg(year(now()) - year(birthdate)) | 
+----+---------------------------- + 
I3 | 17. 0000 | 
Ix | 15.8571 | 
4----4---------------------------- * 


2 rows in set (0.00 sec) 


(5) 创建 新 表 , 新 表 中 包括 学 号 .学 生 姓 名 .课程 号 和 总 评 成 绩 。 其 中 ,总 评 成 绩 一 
final * 0. 8-- daily * 0.2, 
答 : 代码 和 运行 结果 如 下 : 


mysql» create table stu totall 
一 > select student. studentno, student. sname, score. courseno, 
T» final * 0.8 + daily * 0.2 as 'totall' 
一 > from student, score 
一 > where student. studentno = score. studentno; 
Query OK, 26 rows affected (0.54 sec) 
Records: 26 Duplicates: 0 Warnings: 0 
mysql» select * from stu totall; 
4---------- 4------- 4------- 4------ * 
| studentno | sname | courseno | totall| 

















19111133071 | #Æ4kk | c05103 70.0 
19111133071 | &fKk3K | c05109 79.5 
19122203567 | $$ H Bj | co5103 90.1 
19122203567 | 封 月 明 | co5108 87.0 
19122203567 | 封 月 明 | c06127 86.2 
19112111208 | 韩 山川 c05109 88.1 
19123567897 | 赵 既 白 | c06127 99.0 
18137221508 | 赵 临 江 | c08106 91.6 
18137221508 | 赵 临 江 | c08123 86.8 
18137221508 | 赵 临 江 | c08171 96.0 
Pe————— deu——— qpee—————— Pee————- $ 


26 rows in set (0.00 sec) 


(6) 统计 每 个 学 生 的 期 末 成 绩 平均 分 。 
答 : 代码 和 运行 结果 如 下 : 


mysql» select student. studentno, student. sname, avg( score. final) 
一 > from student join score 
-> on student.studentno = score. studentno 
-> group by score. studentno ; 

















perenni entrent dt * 
studentno | sname avg(score.final) | 
+- + 
18122210009 | 许 东山 86. 50000 
18122221324 | 何 白 露 69.50000 
18125111109 | 敬 横江 94. 33333 
18125121107 | 梁 一 苇 76.50000 
18135222201 | 凌 浩 风 87.00000 
18137221508 | 赵 临 江 94. 00000 
19111133071 | 崔 依 歌 75. 50000 
19112111208 | 韩 山川 93.00000 
19122203567 | 封 月 明 91. 66667 
19123567897 | 赵 既 白 99.00000 
19126113307 | 梅 惟 江 93.50000 

4--------- 4------ 二 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 


11 rows in set (0.03 sec) 


(7) 输出 student 表 中 年 龄 最 大 的 男生 的 所 有 信息 。 
答 : 代码 和 运行 结果 如 下 : 


mysql» select * from student st 
一 > where st.birthdate = 





二 区 ( select min(stu.birthdate) from student stu 

一 > where stu.sex- 'H'); 
+- 一 -+ 一 一 一 一 + 一 一 -+ 一 * 
| studentno | sname |sex |birthdate | entrance|phone |Emil | 
4£--------- 4----4----4----- 4-------— 4------- 4------- * 
[18122210009 | FÆ | 58 |1999 - 11 - 05|789|13623456778 |qwe(2163. con| 
4--------- 4----4----4----- 4------- 4------- 4------- * 


TIS 


1 row in set (0.06 sec) 
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(8) 查询 teacher 表 中 没有 职称 的 职工 的 教师 号 、. 姓 名 .专业 和 部 门 。 
答 : 代码 和 运行 结果 如 下 : 


mysql» select teacherno, tname, major, department 
一 > from teacher 
-> where prof is null; 
Empty set (0.03 sec) 





第 6 章 索引 和 视图 





6.1 教学 要 求 


6.1.1 基本 要 求 


(1) 了 解 索引 的 分 类 和 用 途 。 主 要 了 解 索 引 和 表 的 关系 。 

(2) 掌握 索引 的 创建 修改、 删除 等 基本 操作 。 

(3) 学 会 利用 MySQL Workbench 工具 创建 和 管理 索引 。 

(4) 掌握 视图 的 概念 、 功 能 和 有 用途, 了解 索引 和 视图 的 关系 。 

(5) 掌握 视图 的 创建 修改、 删除 等 基本 操作 。 

(6) 掌握 利用 视图 添加 、 删 除 \、 修 改 和 浏览 表 数 据 的 基本 原则 和 基本 操作 。 
(7) 学 会 利用 MySQL Workbench 工具 创建 和 管理 视图 。 

(8) 掌握 检查 视图 的 应 用 。 


6.1.2 重点 与 难点 


1. KARA 

CD RIKOE E Dj Ag AE A Te E 。 

(2) 视图 的 概念 、 功 能 和 用 途 , 了 解 索引 和 视图 的 关系 。 
(3) 掌握 视图 的 创建 ,修改 、 删 除 等 基本 操作 。 

(4) 掌握 利用 视图 添加 、 删 除 ,修改 和 浏览 表 数 据 的 基本 原则 和 基本 操作 。 
(5) 学 会 利用 MySQL Workbench 工具 创建 和 管理 视图 。 
2. 本 章 难 点 

(1) 索引 和 表 的 关系 的 理解 。 

C2) 利用 视图 添加 、 删 除 和 修改 表 数 据 的 条 件 。 

(3) 利用 视图 添加 、 删 除 和 修改 表 数 据 的 基本 操作 。 

(4) 掌握 检查 视图 的 应 用 。 


6.2 习题 参考 答案 
1. 选择 题 


a) 下 列 语句 不 能 用 于 创建 索引 。 


A. create index B. create table 
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C. alter table D. create database 
(2) 下 面 对 索 引 的 相关 描述 正确 的 是 。 

A. 经 常 被 查询 的 列 不 适合 建 索 引 B. 小 型 表 适 合 建 索引 

C. 有 很 多 重复 值 的 列 不 适合 建 索 引 D. 是 外 键 或 主键 的 列 不 适合 建 索引 
(3) MySQL 中 不 可 对 视图 执行 的 操作 有 。 

A. select B. insert C. delete D. create index 


CD 对 视图 的 描述 错误 的 是 š 
A. 视图 是 一 张 虚拟 表 
B. 视图 定义 包含 limit 子 句 时 才能 设置 排序 规则 
C. 可 以 像 查 询 表 一 样 来 查询 视图 
D. 被 修改 数据 的 视图 只 能 是 一 个 基 表 的 列 


(5) with check option 属性 对 视图 有 的 用 途 。 

A. 进行 权限 检查 B. 进行 删除 监测 C. 进行 更 新 监测 D. 进行 插入 监测 
(6) 索引 可 以 提高 操作 的 效率 。 

A. insert B. update C. delete D. select 
(7) 在 MySQL 中 唯一 索引 的 关键 字 是 。 

A. fulltext B. only C. unique D. index 








本 题 答案 : DCDDADC 








2. 思考 题 

COD. 简 述 创建 索引 的 必要 性 。 

答 : 创建 索引 可 以 大 大 提高 系统 的 查询 性 能 ,具体 表现 如 下 : 

CD 加 快 数据 的 检索 速度 。 

@ 通过 创建 唯一 性 索引 ,可 以 保证 每 一 行 数据 的 唯一 性 。 

O 加 速 表 与 表 之 间 的 连接 ,特别 是 在 实现 数据 的 参照 完整 性 方面 具有 特别 的 意义 。 

CD 在 使 用 order by 和 group by 子 句 进行 数据 检索 时 ,可 以 显著 减少 查询 中 分 组 和 排 
序 的 时 间 。 

C) 通过 使 用 索引 ,可 以 在 查询 过 程 中 使 用 查询 优化 器 ,提高 系统 性 能 。 

(2) MySQL 中 普通 索引 、 主 键 和 唯一 索引 的 区 别 是 什么 ? 

答 : MySQL 中 最 常用 的 索引 有 普通 索引 、 唯 一 性 索引 和 主键 索引 等 类 型 。 普 通 索 引 是 
MySQL 中 的 基本 索引 类 型 ,允许 在 定义 索引 的 列 中 插入 重复 值 和 空 值 。 主 键 索引 是 一 种 
特殊 的 唯一 索引 ,不 允许 有 空 值 。 一 般 是 在 建 表 的 时 候 同 时 创建 主键 索引 。 一 个 表 只 能 有 
一 个 主键 索引 。 唯 一 索引 中 索引 列 的 值 必须 唯一 ,允许 有 空 值 。 如 果 是 组 合 索引 , 则 列 值 的 
组 合 必须 唯一 。 在 一 个 表 上 可 以 创建 多 个 unique 索引 。 

(3) 简 述 表 和 视图 之 间 的 关系 。 

E, 视图 是 从 一 个 或 多 个 基本 表 导 出 的 虚 表 , 它 的 数据 并 不 存储 在 数据 库 中 ,视图 中 的 
数据 来 自 定义 视图 的 查询 所 引用 的 表 。 视 图 的 查询 可 像 基本 表 一 样 参与 数据 库 操作 ,但 视 
图 的 更 新 最 终 落 实 到 有 关 基 本 表 的 更 新 上 。 


(4) 简 述 创建 视图 的 必要 性 。 

答 : 创建 视图 的 必要 性 分 析 如 下 : 
CD 将 数据 集中 显示 ,简化 用 户 的 数据 查询 和 处 理 。 

© 简化 数据 操作 ,将 数据 库 的 设计 和 用 户 的 使 用 分 离开 来 ,屏蔽 数据 库 的 复杂 性 。 

C 重新 定制 数据 ,使 得 数据 便于 共享 。 组 合 分 区 数据 ,可 将 来 自 不 同 表 的 多 个 查询 结 


果 组 合成 单一 的 结果 集 ， 


利于 用 户 查 询 和 使 用 。 


@ 简化 用 户 权 限 的 管理 ,增强 了 安全 性 。 
3. 上 机 练习 题 (本 题 利用 teaching 数据 库 中 的 表 进行 操作 ) 
(1) 在 course 表 的 cname 列 上 创建 索引 IDX_cname。 

答 : 代码 和 运行 结果 如 下 : 


mysql > use teaching; 


Database changed 

mysql > create index IDX cname on course(cname) ; 
Query OK, 0 rows affected (0.47 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


(2) 在 student 表 的 studentno 和 phone 列 上 创建 唯一 索引 uq_stu, 并 输出 student 表 


中 的 记录 ,查看 输出 结果 的 顺序 。 
答 : 代码 和 运行 结果 如 下 : 


mysql > create index unique uq stu on student(studentno, phone) ; 
Query OK, 0 rows affected (0.16 sec) 
Records: 0 Duplicates: 0 Warnings: 0 

mysql» select studentno, phone, sname from student; 








4---------- + 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 + 
studentno | phone | sname | 
4---------- + 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 + 
18122210009 | 13623456778 | 许 东山 | 
18122221324 | 13178978999 | 何 白露 | 
18125111109 | 15678945623 | 敬 横 江 | 
18125121107 | 132123456777 | 梁 一 苇 | 
18135222201 | 15978945645 | 凌 浩 风 | 
18137221508 | 12367823453 | 赵 临 江 | 
19111133071 | 15556845645 | 崔 依 歌 | 
19112111208 | 15878945612 | 韩 山川 | 
19122203567 | 13245674564 | 封 月 明 | 
19123567897 | 13175689345 | 赵 既 白 | 
19126113307 | 13245678543 | 梅 惟 江 | 

4---------- 4---------- 4----- * 


11 rows in set (0.00 sec) 


(3) 创建 一 个 视图 v_teacher, 查 询 所 有 “计算 机 学 院 ” 教 师 的 信息 。 
答 : 代码 和 运行 结果 如 下 : 


mysql > create view v teacher 


-»as 
-» select * 





(MySQL 4E B I 5 7E UR EX 


y4- 


MySQL 4t 4E E E JH 5 7E A LEE 5 Edu 





一 > from teacher 
一 > where department = ' 计 算 机 学 院 '; 
Query OK, 0 rows affected (0.07 sec) 
mysql» select * from v teacher; 
二 descente doses doe Jessnes + 
| teacherno | tname | major | prof | department | 


| t05001 | 苏 超然 ”| 软件 工程 | 教授 ”| 计算 机 学 院 | 
| t05003 “| HRR | 网 络 安全 | 教授 ”| 计算 机 学 院 | 
| t05011 pra | 软件 工程 | 副教授 | 计算 机 学 院 | 
| to5017 ”| 茅 佳 峰 | 软件 测试 | 讲师 | 计算 机 学 院 | 
4--------- 4----- 4------ 4----- 4--------- * 


4 rows in set (0.03 sec) 


(4) 创建 一 个 视图 v_avgstu, 查 询 每 个 学 生 的 学 号 、 姓 名 及 平均 分 ,并 且 按 照 平均 分 降 
序 排序 。 
答 : 代码 和 运行 结果 如 下 : 


mysql > create view v_avgstu 
-»as 
-> select student. studentno, student. sname, 
一 > avg(score. final) as'average' 
一 > from student, score 
一 > where student.studentno = score. studentno 
=> and score. final is not null 
一 > group by student. studentno, student. sname 
一 > order by avg( score. final) desc; 
Query OK, 0 rows affected (0.11 sec) 
mysql» select * from v avgstu; 


4--------- 4------- 4-------- * 
studentno | sname average | 
*--------- 4------- 4-------- * 


19123567897 | 赵 既 白 | 99.00000 
18125111109 | 敬 横 江 | 94.33333 
18137221508 | 赵 临 江 | 94.00000 
19126113307 | 梅 惟 江 | 93.50000 
19112111208 | 韩 山川 | 93.00000 
19122203567 | tt H BH | 91.66667 
18135222201 | 凌 浩 风 | 87. 00000 
18122210009 | 许 东 山 | 86. 50000 
18125121107 | 梁 一 革 | 76.50000 
19111133071 | 崔 依 歌 | 75.50000 
18122221324 | 何 白露 | 69.50000 














11 rows in set (0.02 sec) 


(5) 修改 v_teacher 的 视图 定义 ,添加 with check option 选项 。 
A. 代码 和 运行 结果 如 下 : 


mysql» alter view v teacher 
-»as 


一 > select * from teacher 
-> where department = “计算 机 学 院 ' 
—» with check option ; 

Query OK, 0 rows affected (0.06 sec) 


(6) 通过 视图 v. teacher 向 基 表 teacher 中 分 别 插入 下 列 数据 ,并 查看 插入 数据 的 情况 。 


(t05039', SE H ', HEREBUE RU, "UEWU, SESEBUE BC) 
('t06018'，' 李 书 诚 '，' 机 械 制造 ', "副教授 ', ' 机 械 学 院 ') 


答 : 代码 和 运行 结果 如 下 : 


mysql > insert into v_teacher 
-> values('t05039', ' 张 声 月 ', ' 计 算 机 应 用 ', "WERE, ' 计 算 机 学 院 '); 
Query OK, 1 row affected (0.06 sec) 
mysql > insert into v_teacher 
->  velues('t06018', AE Bk", ' 机 械 制 造 ', ' 副 教授 ', ' 机 械 学 院 '); 
ERROR 1369 (HY000): CHECK OPTION failed 'teaching.v teacher' 
mysql» select * from v teacher; 


05001 苏 超然 | 软件 工程 “| 教授 | 计算 机 学 院 | 
t05003 孙 释 安 | 网 络 安全 ”| 教授 — | 计算 机 学 院 | 
t05011 PR | 软件 工程 。 | 副教授 | 计算 机 学 院 | 
t05017 FEE | 软件 测试 | 讲师 | 计算 机 学 院 | 
t05039 KRA “| 计算 机 应 用 | 讲师 | 计算 机 学 院 | 


5 rows in set (0.00 sec) 
mysql > select * from teacher; 


4---------- 4----4--------- 4------ 4--------- * 
teacherno | tname | major | prof |department| 
4---------- 4----—4--------- 4------ 4--------- * 


05001 苏 超然 | 软件 工程 ”| 教授 ”| 计算 机 学 院 
t05002 常 杉 会 计 学 | 助教 管理 学 院 
t05003 WER | 网 络 安 全 ”| 教授 计算 机 学 院 
t05011 PRI 软件 工程 ”| 副教授 | 计算 机 学 院 
t05017 FIER | 软件 测试 ”| 讲师 计算 机 学 院 
t05039 KEA | 计算 机 应 用 | 讲师 ”| 计算 机 学 院 
t06011 夏 南 望 | 机械 制造 ”| 教授 | 机 械 学 院 
t06023 BEF | 铸造 工艺 。 | 副教授 | 材料 学 院 
t06027 陶 期 年 | 纳米 技术 | 教授 ”| 材料 学 院 
t07019 韩 既 乐 | 经 济 管理 | 副教授 | 管理 学 院 

















10 rows in set (0.00 sec) 


(7) 通过 视图 v_teacher 将 基 表 teacher 中 教师 编号 为 t05039 的 教师 职称 修改 为 “ 副 
答 : 代码 和 运行 结果 如 下 : 


mysql > update v teacher 
一 > set prof = ' 副 教授 ' 


yi-w 
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一 > where teacherno = 't05039'; 
Query OK, 1 row affected (0.07 sec) 
Rows matched: 1 Changed: 1 Warnings: 0 

mysql» select * from teacher 

一 > where teacherno = 't05039'; 
jii j fa EES T EEEE + 
| teacherno | tname | major | prof | department | 
s 
| t05039 | 3A | 计算 机 应 用 | 副教授 ”| 计算 机 学 院 | 


+ 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 4---------- * 





1 row in set (0.00 sec) 





第 7 章 MySQL 编程 基础 





7.1.1 基本 要 求 


(1) 掌握 系统 变量 的 用 途 和 使 用 方法 。 

(2) 掌握 会 话 变量 的 定义 方法 和 使 用 方法 ,了解 MySQL 中 使 用 会 话 变量 的 机 制 ,以 及 
会 话 变量 与 局 部 变量 的 区 别 。 

(3) 掌握 定 界 符 delimiter, begin...end 语句 块 和 预 处 理 SQL 语句 的 用 途 。 

(4) 掌握 创建 修改、 删除 和 调用 自 定义 函数 的 格式 和 方法 。 

(5) 了 解 MySQL 中 利用 控制 流 语句 编程 的 过 程 。 

(6) 掌握 让 和 case 等 条 件 控制 语句 的 格式 、 功 能 和 执行 过 程 。 

(7) 掌握 while, loop, repeat 等 循环 语句 的 格式 、 功 能 和 执行 过 程 。 

(8) 学 会 编写 较为 复杂 的 自 定义 函数 。 


7.1.2 重点 与 难点 


1. 本 章 重点 

CD. 会 话 变量 的 定义 方法 和 使 用 方法 ,以 及 会 话 变量 与 局 部 变量 的 区 别 。 
(2) 定 界 符 delimiter begin... end 语句 块 和 预 处 理 SQL 语句 的 用 途 。 
(3) 创建 修改、 删除 和 调用 自 定义 函数 的 格式 和 方法 。 

(4) if AI case 等 条 件 控制 语句 的 格式 、 功 能 和 执行 过 程 。 

(5) while, loop, repeat 等 循环 语句 的 格式 、 功 能 和 执行 过 程 。 

(6) 编写 较为 复杂 的 自 定义 函数 。 

2. 本 章 难点 

OD MySQL 中 使 用 会 话 变 量 的 机 制 , 以 及 会 话 变 量 与 局 部 变量 的 区 别 。 
(2) 预 处 理 SQL 语句 的 定义 和 使 用 。 

(3) 让 和 case 等 条 件 控制 语句 的 执行 过 程 。 

(4) while、loop、repeat 等 循环 语句 的 格式 、 功 能 和 执行 过 程 。 
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7.2 习题 参考 答案 


1. 选择 题 
(1) 在 MySQL 语句 中 ,可 以 匹配 0 个 到 多 个 字符 的 通配符 是 : 

A. * B. % C. ? D. - 
(2) MySQL 提供 的 单行 注释 语句 可 以 是 使 用 开始 的 一 行内 容 。 

A. /* B. # €: 1 D. 7 
(3) 在 MySQL 中 会 话 变量 前 面 的 字符 为 > 

A, * B. # C. @@ D. @ 
(4) 若 要 计算 表 中 数据 的 平均 值 ,可 以 使 用 的 函数 是 。 

A. sqrt B. avg C. square D. count 
(5) 语句 用 于 执行 预 处 理 语句 。 

A. prepare B. deallocate C. execute D. using 





本 题 答 案 : BBDBC 











2. 思考 题 

A) MySQL 的 语言 要 素 有 哪些 ? 主要 作用 是 什么 ? 

B: MySQL 语言 的 要 素 及 主要 用 途 如 下 : 

CD 标识 符 ,标识 符 是 用 来 命名 一 些 如 数据 库 . 表 、 视 图 ,存储 过 程 等 数据 库 对 象 名 称 的 
字符 序列 ,该 序列 由 以 字母 或 下 画 线 开头 的 字母 .数字 或 下 画 线 (_) 序 列 组 成 。 

@ 常量 ,表示 一 个 特定 数据 值 的 符号 ,其 格式 取决 于 它 所 表示 的 值 的 数据 类 型 。 

@ 变量 ,一 种 是 用 户 自 己 定 义 的 局 部 变量 和 会 话 变量 ,另外 一 种 是 系统 提供 的 全 局 变 
量 。 用 于 存储 某 过 程 中 可 以 变化 的 值 。 

CD 注释 ,程序 代码 中 不 可 执行 的 文本 字符 串 ,增加 程序 的 可 读 性 。 

C 运算 符 , 用 来 执行 算术 运算 .字符 串 连接 .赋值 以 及 在 字段 .常量 和 变量 之 间 进 行 比 
较 的 操作 符 。 

© 函数 ,能 够 返回 一 个 值 的 程序 段 。 

D 表达 式 , 指 符号 和 运算 符 的 组 合 ,其 计算 结果 为 单个 数据 值 。 

MySQL 语句, 主要 功能 是 创建 和 管理 数据 库 对 象 . 插 入 、 检 索 、 修 改 和 删除 数据 ,并 
实现 服务 器 和 客户 端的 操作 和 管理 。 

(2) 如 何 定义 变量 ,如 何 给 变量 赋值 ? 

答 : 定义 局 部 变量 需要 使 用 declare 命令 ,会话 变量 可 以 直接 定义 和 赋值 等 ,要 在 其 名 
称 前 加 上 标志 “@”, 使 用 全 局 变量 时 ,必须 以 标记 符 "@@” 开 头 。 

为 变量 赋值 需要 使 用 set 和 select 命令 。set 命令 一 次 只 能 为 一 个 变量 赋值 , select fr 
令 可 以 同时 为 多 个 变量 赋值 。select 命令 的 赋值 号 为 * := 二 ”。 

(3) 流程 控制 语句 包括 哪些 类 型 ? 各 自 的 作用 是 什么 ? 

E. 控制 流 语句 主要 包括 if... else 选择 语句 和 case 多 分 支 语句 ,语句 复合 体 begin... 


end 语句 块 ,while loop 和 repeat 等 循环 语句 。MySQL 提供 的 控制 流 语句 主要 用 于 控制 程 
序 的 顺序 .选择 和 循环 流程 。 

(4) MySQL 语句 共 分 几 类 ,各 自 的 主要 功能 是 什么 ? 

答 : MySQL 语句 共 分 为 4 类 ,其 主要 作用 如 下 : 

CD 数据 定义 语言 ,数据 库 对 象 的 创建 ,修改 和 删除 等 都 可 以 通过 数据 定义 语言 中 的 
create、alter drop 等 语句 来 完成 。 

@ 数据 操纵 语言 。 用 于 检索 和 操作 数据 的 SQL 语句 的 子 集 。 数 据 操纵 语言 是 指 用 来 
查询 、 添 加 、 修 改 和 删除 数据 库 中 数据 的 语句 ,这 些 语句 包括 select, insert, update, delete 等 
命令 。 

© 数据 控制 语言 ,用 来 设置 或 更 改 数 据 库 用 户 或 角色 权限 的 语句 ,包括 grant, revoke 
等 命令 。 

CD 控制 流 语句 ,用 于 控制 SQL 语句 .语句 块 或 者 存储 过 程 的 执行 流程 。 流 程控 制 请 句 
包括 begin...end,if... else, while,loop,return 等 语句 。 

3. 上 机 练习 题 

(1) 利用 预 处 理 SQL 语句 输出 数据 库 teaching 中 teacher 表 的 前 5 行 记录 的 部 分 
数据 。 

答 : 代码 和 运行 结果 如 下 : 

mysql> set @a = 5; 

Query OK, 0 rows affected (0.00 sec) 
mysql> prepare pteac 
-> from "select * from teacher limit ?"; 
Query OK, 0 rows affected (0.00 sec) 


Statement prepared 
mysql > execute pteac using @a; 


4--------- 4------- 4--------- 4-------- $--------- * 
| teacherno | tname | major | prof |department | 
4--------- 4------- 4--------- 4-------- 4--------- * 


| t05001 | 苏 超然 | 软件 工程 ”| 教授 | 计算 机 学 院 | 
| t05002 | 常 杉 | 会 计 学 | 助教 | 管理 学 院 | 
| t05003 | 孙 释 安 | 网 络 安全 | 教授 | 计算 机 学 院 | 
| t05011 pod | 软件 工程 ”| 副教授 ”| 计算 机 学 院 | 
| t05017 | 茅 佳 峰 | 软件 测试 ”| 讲师 | 计算 机 学 院 | 


5 rows in set (0.06 sec) 


(2) 创建 函数 casetwo, 通 过 case 语句 首先 判断 传人 参数 的 值 是 否 为 7, 如 果 条 件 成 立 
则 输出 1, 如 果 条 件 不 成 立 则 再 判断 该 传人 参数 的 值 是 否 为 14, 如 果 成 立 则 输出 2, 当 以 上 
条 件 都 不 满足 时 输出 一 1。 

B: 代码 和 运行 结果 如 下 : 

mysql> delimiter // 

mysql> create function casetwo(x int) 


-» returns int 
一 > DETERMINISTIC 
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一 > begin 

-»case x 

一 > when 7 thenset x-1; 

一 > when 14 then set x=2; 

-» else set x= -1; 

一 > end case; 

-»return x; 

-> end // 

Query OK, 0 rows affected (0.03 sec) 

mysql» delimiter ; 
mysql» select casetwo (14); 


€— + 
| casetwo(14) | 
出 = 二 = * 
| 2 | 
a 十 


1 row in set (0.02 sec) 


(3) 定义 函数 exthree, 应 用 while 语句 编程 求 50 到 指定 整数 的 所 有 奇数 之 和 。 
答 : 代码 和 运行 结果 如 下 : 


mysql > delimiter // 
mysql» create function exthree(sn int) returns int 
一 > DETERMINISTIC 
-> begin 
一 > declare sum int default 0; 
一 > declare n int default 0; 
-> set n=51; 
-> while n<=sn do 
-> set sum= sum+ n; 
-> set n=n+2; 
-> end while; 
-» return sum; 
-» end // 
Query OK, 0 rows affected (0.03 sec) 
mysql > delimiter ; 
mysql> select exthree(150); 


4---------- * 
| exthree(150) | 
4---------- * 
| 5000 | 
4---------- * 


1 row in set (0.00 sec) 


(4) 定义 函数 exfour, 应 用 while 语句 和 iterate 语句 求 100 一 150 的 偶数 之 和 。 通 过 
leave 语句 退出 循环 并 输出 结果 。 

答 : 代码 和 运行 结果 如 下 : 

mysql > delimiter // 


mysql» create function exfour (n int) 
一 > returns int 


— » DETERMINISTIC 

一 > begin 

—» declare sum char(20) default 0; 

-> declare s int default 100; 

一 > add num: while true do 

-»sets-2st2; 

-> if (s&2-70) then 

-> set sum- sum + s; 

-> else 

一 > iterate add num; 

-> end if; 

-> if(s-n) then 

-> leave add num; 

-» endif; 

-> end while add num; 

-» return sum; 

-» end// 

Query OK, 0 rows affected (0.03 sec) 

mysql» delimiter ; 
mysql» select exfour (150); 


4---------- * 
| exfour (150) | 
4---------- * 
| 3150 | 
4---------- * 


1 row in set (0.01 sec) 
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第 8 章 存储 过 程 .游标 和 触发 器 





8.1.1 基本 要 求 


CD 了 解 存储 过 程 的 功能 ,以 及 存储 过 程 与 游标 .触发 器 和 事件 的 关系 。 
(2) 掌握 存储 过 程 的 创建 ,修改 、 删 除 和 调用 方法 。 

(3) 学 会 利用 MySQL Workbench 工具 管理 存储 过 程 。 

(4) 了 解 游标 的 作用 和 定义 、 使 用 方法 。 

(5) 了 解 触 发 器 的 功能 ,了 解 触 发 器 和 数据 表 的 关系 。 

(6) 掌握 触发 器 的 创建 ,修改 、 删 除 和 调用 方法 。 

(7) 了 解 事件 的 功能 ,以 及 事件 与 触发 器 的 区 别 。 

(8) 掌握 事件 的 创建 和 使 用 方法 。 


8.1.2 重点 与 难点 


1. 本 章 重 点 

(1) 存储 过 程 的 功能 ,以 及 存储 过 程 与 游标 、 触 发 器 和 事件 的 关系 。 
(2) 存储 过 程 的 创建 ,修改 、 删 除 和 调用 方法 。 
(3) 游标 的 作用 和 定义 、 使 用 方法 。 

(4) 触发 器 的 功能 ,了 解 触发 器 和 数据 表 的 关系 。 
(5) 触发 器 的 创建 、 修 改 、 删 除 和 调用 方法 。 

(6) 事件 的 创建 和 使 用 方法 。 

2. 本 章 难 点 

CD 存储 过 程 的 创建 ,修改 和 调用 方法 。 

(2) 利用 游标 访问 结果 集 的 方法 。 

(3) 触发 器 的 创建 修改 和 调用 方法 。 

(4) 事件 的 创建 和 使 用 方法 。 


8.2 习题 参考 答案 





1. 选择 题 
(1) 存储 过 程 是 在 MySQL 服务 器 中 定义 并 的 SQL 语句 集合 。 


A. 保存 B. 执行 C. 解释 D. 编写 
(2) 下 面 有 关 存 储 过 程 的 叙述 错误 的 是 A 

A. MySQL 允许 在 存储 过 程 创建 时 引用 一 个 不 存在 的 对 象 

B. 存储 过 程 可 以 带 多 个 输入 参数 ,也 可 以 带 多 个 输出 参数 

C. 使 用 存储 过 程 可 以 减少 网 络 流量 

D. 在 一 个 存储 过 程 中 不 可 以 调用 其 他 存储 过 程 


(3) MySQL 所 支持 的 触发 器 不 包括 。 
A. insert 触发 器 B. delete 触发 器 
C. check 触发 器 D. update 触发 器 
(4) 下 面 有 关 和 触发 器 的 叙述 错误 的 是 


A. 触发 器 是 一 个 特殊 的 存储 过 程 

D. 触发 器 不 可 以 引用 所 在 数据 库 以 外 的 对 象 
C. 在 一 个 表 上 可 以 定义 多 个 触发 器 

D. 触发 器 在 check 约束 之 前 执行 


(5) MySQL 为 每 个 触发 器 创建 了 两 个 临时 表 。 
A. max 和 min B. avg 和 sum C. int 和 char D. old fll new 
(6) 通过 以 下 语句 临时 关闭 事件 e_test。 
A. alter event e_test disable B. alter event e_test drop 
C. alter event e test enable D. alter event e test delete 
(7) 下 列 语句 用 来 定义 游标 。 
A. create B. declare 
C. declare...cursor for ... D. show 
(8) 下 列 说 法 中 错误 的 是 。 


A. 常用 触发 器 有 insert, update,delete 三 种 

B. 对 于 同一 张 数 据 表 ,可 以 同时 有 两 个 before update 触发 器 
C. new 临时 表 在 insert 触发 器 中 用 来 访问 被 插入 的 行 

D. old 临时 表 中 的 值 只 读 不 能 被 更 新 


(9) 存储 程序 中 的 选择 语句 有 。 

A. if B. while C. select D. switch 
(10) 存储 程序 中 不 能 使 用 的 循环 语句 是 

A. repeat B. while C. loop D. for 








本 题 答案 : BDCBDACBAD 








2. 思考 题 
A) MySQL 中 创建 多 条 执行 语句 的 存储 过 程 或 触发 器 时 ,为 何 总 是 遇 到 分 号 就 结束 创 


建 ,然后 报错 ? 如 何 解决 这 个 问题 ? 


/& . MySQL 中 ,创建 多 条 执行 语句 的 触发 器 时 ,需要 用 到 begin...end 的 形式 。 每 个 执 


行 语句 都 必须 以 分 号 结束 。 但 是 ,这 样 就 会 出 问题 。 因 为 系统 默认 分 号 是 SQL 程序 结束 的 
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标志 , 遇 到 分 号 整个 程序 就 结束 了 。 要 解决 这 个 问题 ,就 需要 delimiter 语句 来 改变 程序 的 
结束 符号 。 如 “delimiter &&” 可 以 将 程序 的 结束 符号 变 成 “&&”。 如 果 要 把 结束 符号 变 回 
分 号 ,只 要 执行 “delimiter ;” 即 可 。 

(2) 各 种 触发 器 的 触发 顺序 是 什么 ? 

答 : 使 用 触发 器 时 ,触发 器 执行 的 顺序 是 before 触发 器 、 表 操作 (insert, update 和 
delete) „after 触发 器 。 

(3) 什么 是 事件 ? 事件 有 什么 作用 ? 事件 与 触发 器 的 区 别 有 哪 些 ? 

答 : 事件 就 是 需要 在 指定 的 时 刻 才 被 执行 的 某 些 特定 任务 ,其 中 这 些 特 定 任务 通常 是 
一 些 确定 的 SQL 语句 。 

事件 可 以 根据 需要 在 指定 的 时 刻 被 事件 调度 器 调用 执行 ,并 可 以 此 取代 原先 只 能 由 操 
作 系 统 的 计划 任务 来 执行 的 工作 。 

事件 和 触发 器 相似 ,都 是 在 某 些 事情 发 生 的 时 候 才 被 启动 ,但 事件 是 基于 特定 时 间 周 期 
触发 来 执行 某 些 任 务 的 ,而 触发 器 是 基于 某 个 表 所 产生 的 事件 触发 的 ,它们 的 区 别 也 在 
于 此 。 

(4) 简 述 游标 在 存储 过 程 中 的 作用 。 

答 : 游标 是 一 个 被 select 语句 检索 出 来 的 结果 集 。 在 存储 了 游标 后 ,应 用 程序 或 用 户 
就 可 以 根据 需要 滚动 或 浏览 其 中 的 数据 。 

(5) 简 述 存储 过 程 与 存储 函数 的 区 别 。 

答 : 存储 函数 与 存储 过 程 之 间 存在 的 几 点 区 别 为 : 存储 函数 不 能 拥有 输出 参数 ,这 是 
因为 存储 函数 自身 就 是 输出 参数 ; 而 存储 过 程 可 以 拥有 输出 参数 。 可 以 直接 对 存储 函数 进 
行 调用 , 且 不 需要 使 用 call 语句 ; 而 对 存储 过 程 的 调用 ,需要 使 用 call 语句 。 存 储 函 数 中 必 
须 包含 一 条 return 语句 ,而 这 条 特殊 的 SQL 语句 不 允许 包含 于 存储 过 程 中 。 

3. 上 机 练习 题 (以 下 题目 默认 数据 库 为 teaching? 

(1) 创建 存储 过 程 selectscore() ,用 指定 的 学 号 查询 学 生成 绩 。 

答 : 代码 和 运行 结果 如 下 : 

mysql» delimiter $$ 

mysql» create procedure selectscore(in s no char(11)) 

一 > begin 
-> select * from score 
一 > where studentno- s no ; 
-» end $$ 


Query OK, 0 rows affected (0.01 sec) 
mysql» delimiter ; 


调用 存储 过 程 selectscore() 的 代码 和 执行 结果 如 下 : 


mysql» call selectscore('19112111208'); 
4*---------- 4------- 4----- 4------- * 
| studentno | courseno | daily | final | 
4*---------- 4------- 4----- 4------- * 
| 19112111208 | co5109 | 76.5| 91.0| 
| 19112111208 | c06108 | 89.0| 95.0| 
4---------- 4------- 4----- 4------- * 


2 rows in set (0.08 sec) 
Query OK, 0 rows affected (0.09 sec) 


(2) 编程 在 表 course 中 创建 一 个 触发 器 course_detrigger, 用 于 每 次 当 删 除 表 course 中 
一 行 数据 时 ,将 会 话 变 量 perl ffo ftit 8 7g "old course deleted!”。 
答 : 代码 和 运行 结果 如 下 : 


mysql» create trigger course detrigger after delete 
一 > on course for each row set (perl = 'old course deleted! '; 
Query OK, 0 rows affected (0.05 sec) 
mysql > delete from course where courseno = 'c08171'; 
Query OK, 1 row affected (0.20 sec) 
mysql» select (perl; 


——ÁÓ€— 4 
| Gperi 1 
市 = 二 一 + 
| old course deleted! | 
机 = 二 = 一 = + 


1 row in set (0.00 sec) 
(3) 创建 一 个 存储 过 程 ,用 于 实现 给 定 表 student 中 一 个 学 生 的 姓名 即 可 修改 表 


student 中 该 人 的 电子 邮件 地 址 为 一 个 给 定 的 值 。 
答 : 代码 和 运行 结果 如 下 : 


mysql» delimiter $$ 
mysql» create procedure update email(in user name 
一 > char(11), in e mail varchar(20)) 
一 > begin 
-> update student set Email = e mail where sname = user name; 
-» end $$ 
Query OK, 0 rows affected (0.04 sec) 
mysql» delimiter ; 
mysql» call update email('fjJj Bj', 'feng(2163.com'); 
Query OK, 1 row affected (0.10 sec) 
mysql» select studentno, sname, email from student where sname = 'fj H Hj'; 


4---------- 4------ 4------------ * 
| studentno | sname | email | 
4---------- 4------ 4------------ * 
| 19122203567 | 封 月 明 | feng(2163. con | 
4---------- *------ 4------------ * 


1 row in set (0.02 sec) 


(4) 创建 一 个 事件 ,用 于 每 6 个 月 将 表 score 中 期 末 成 绩 高 于 60 分 的 所 有 记录 信息 删 
除 ,该 事件 开始 于 下 个 月 并 且 在 2019 4 12 月 31 日 结束 。 

答 : 代码 和 运行 结果 如 下 : 

mysql» delimiter $$ 

mysql» create event if not exists e delete final 


一 > on schedule every 6 month 
一 > starts curdate() + interval 2 month 


y4- 





(MySQL 4E E lS TED EX 


MySQL 4t 4E E E JH 5 TER LEE 5 Edu 





-> ends '2019- 12- 31' 

-> do 

一 > begin 

-> if year(curdate())« 2019 then 

一 > delete from score 

一 > where final» - 60; 

一 > end if; 

-»end $$ 

Query OK, 0 rows affected (0.09 sec) 

mysql > delimiter ; 


CO 创建 一 个 存储 过 程 scorelnfo, 完 成 的 功能 是 在 表 student, 4€ course 和 表 score 中 
查询 以 下 字段 : 学 号 、 姓 名、 性 别 . 课 程 名 称 、 期 末 分 数 。 
答 : 代码 和 运行 结果 如 下 : 


mysql > delimiter $$ 
mysql > create procedure scoreinfo() 
一 > begin 
一 > select student. studentno, sname, sex, cname, final 
一 > from student, course, score 
一 > where student. studentno = score. studentno 
-» and score. courseno - course. courseno ; 
-»end $$ 
Query OK, 0 rows affected (0.03 sec) 


(6) 创建 一 个 带 有 参数 的 存储 过 程 stu_age, 该 存储 过 程 根据 输入 的 学 号 ,在 student 表 
中 计算 此 学 生 的 年 龄 ,并 根据 程序 的 执行 结果 返回 不 同 的 值 ,程序 执行 成 功 ,返回 整数 0, 如 
果 执 行 出 错 , 则 返回 错误 号 。 

答 : 代码 和 运行 结果 如 下 : 


mysql > delimiter $$ 
mysql» create procedure stu age(in stuno char(11)) 
一 > begin 
-> select (year(curdate()) - year(birthdate)) from student 
一 > where studentno = stuno; 
-> set @er val- @@error count ; 
-» end $$ 
Query OK, 0 rows affected (0.02 sec) 
mysql» delimiter ; 
mysql» call stu age('19122203567'); 





1 row in set (0.00 sec) 
Query OK, 0 rows affected (0.01 sec) 
mysql» select (Jer val; 


| Ger val | 


1 row in set (0.00 sec) 


(7) 创建 事件 e_test, 每 天 定时 清空 test 表 ,5 天 后 停止 执行 。 
答 : 代码 和 运行 结果 如 下 : 


mysql» create event e test 
一 > on schedule every 1 day 
一 > starts curdate() 
-> ends curdate() + interval 5 day 
-> do 
一 > delete from test ; 
Query OK, 0 rows affected (0.04 sec) 


(8) 假设 之 前 创建 的 course 表 没 有 设置 外 键 级 联 策略 ,设置 触发 器 ,实现 在 course X 
中 删除 课程 信息 时 ,可 自动 删除 该 课程 在 score 上 的 成 绩 信息 。 
答 : 代码 和 运行 结果 如 下 : 


mysql» create trigger detrigger after delete 
一 > on course for each row 
一 > delete from score 
一 > where score.courseno = old.courseno ; 
Query OK, 0 rows affected (0.05 sec) 
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第 9 章 并 发 事务 与 锁 机 制 


9.1.1 基本 要 求 


A) 了 解 MySQL 中 的 事务 概念 及 事务 运行 机 制 ,掌握 事务 ACID 特性 的 内 涵 。 
(2) 了 解 事务 并 发 处 理 对 数据 的 影响 。 

(3) 掌握 事务 的 启用 、 删 除 ` 回 滚 、 提 交 和 设置 检查 点 的 常用 操作 。 

(4) 掌握 改变 MySQL 的 自动 提交 模式 的 基本 操作 。 

(5) 掌握 事务 隔离 级 别 用 途 和 设置 事务 的 隔离 级 别 的 基本 操作 。 

(6) 理解 锁 机 制 对 于 并 发 事务 处 理 的 作用 。 

(7) 掌握 锁 的 分 类 方法 和 各 种 锁 的 应 用 场合 。 

(8) 了 解 死 锁 的 概念 和 处 理 过 程 。 


9.1.2 重点 与 难点 


1. 本 章 重 点 

(1) 事务 ACID 特性 的 内 涵 。 

(2) 事务 并 发 处 理 对 数据 的 影响 。 

(3) 事务 的 启用 、 删 除 、 回 滚 .提交 和 设置 检查 点 的 常用 操作 。 
(4) 改变 MySQL 的 自动 提交 模式 的 基本 操作 。 

(5) 设置 事务 的 隔离 级 别 的 基本 操作 。 

(6) 掌握 锁 的 分 类 方法 和 各 种 锁 的 应 用 场合 。 

2. 本 章 难 点 

(1) MySQL 中 的 事务 概念 及 事务 运行 机 制 。 

(2) 事务 并 发 处 理 对 数据 的 影响 。 

(3) 事务 的 启用 删除、 回 滚 .提交 和 设置 检查 点 的 常用 操作 。 
(4) 理解 锁 机 制 对 于 并 发 事务 处 理 的 作用 。 

(5) 锁 的 分 类 方法 和 各 种 锁 的 应 用 场合 。 

(6) 死 锁 的 概念 和 处 理 过 程 。 


9.2 习题 参考 答案 


1. 选择 题 
(D MySQL 的 事务 不 具有 的 特征 是 > 

A. 原子 性 B. 隔离 性 C. 一 致 性 D. 共享 性 
(2) MySQL 中 常见 的 锁 类 型 不 包括 s 

A. 共享 B. 意向 C. 架构 D. 排他 
(3) 事务 的 隔离 级 别 不 包括 s 

A. read uncommitted B. read committed 

C. repeatable read D. repeatable only 
(4) 死 锁 发 生 的 原因 是 

A. 并 发 控制 B. 服务 器 故障 C. 数据 错误 D. 操作 失误 
(5) MySQL 中 发 生死 锁 需要 

A. 用 户 处 理 B. 系统 自动 处 理 。 C. 修改 数据 源 D. 取消 事务 








本 题 答案 : DCDAB 








2. 思考 题 
(1) 简 述 并 发 控制 可 能 产生 的 影响 ,分 别 描述 产生 的 原因 。 
答 : 多 个 用 户 访 问 同一 个 数据 资源 时 ,可 能 出 现 并 发 问题 ,其 产生 的 原因 包括 如 下 4 个 


(D 更 新 丢失 。 当 两 个 或 多 个 事务 选择 同一 行 ,然后 根据 最 初 选 定 的 值 更 新 该 行 时 ,就 


会 出 现 更 新 丢失 的 问题 。 每 个 事务 都 不 知道 其 他 事务 的 存在 。 最 后 的 更 新 将 覆盖 其 他 事务 
所 做 的 更 新 ,从 而 导致 数据 丢失 。 


O 不 可 重复 读 。 当 一 个 事务 多 次 访问 同一 行 且 每 次 读 取 不 同 数据 时 ,会 出 现 不 可 重复 


读 问题 。 因 为 其 他 事务 可 能 正在 更 新 该 事务 正在 读 取 的 数据 。 


© 幻 读 。 当 对 某 行 执行 插入 或 删除 操作 , 而 该 行 属 于 某 事务 正在 读 取 的 行 的 范围 时 ， 


就 会 出 现 幻 读 问题 。 


CD 脏 读 , 即 读 出 的 是 不 正确 的 临时 数据 。 例 如 , 当 第 2 个 事务 选择 第 1 个 事务 正在 更 


新 的 行 时 ,就 会 出 现 此 问题 。 第 2 个 事务 正在 读 取 的 数据 尚未 被 其 他 事务 提交 ,并 可 能 由 更 
新 此 行 的 事务 更 改 。 


(2) 如 何 设置 事务 的 隔离 级 别 ? 
答 : 事务 可 以 设置 隔离 级 别 , 隔 离 级 别 描述 了 一 个 事务 必须 与 其 他 事务 所 进行 的 资源 


或 数据 更 改 相隔 离 的 程度 。 隔 离 级 别 从 人 允许 并 发 负面 影响 (如 脏 读 、 幻 读 等 ) 的 角度 进行 描 
述 。MySQL 支持 的 事务 的 隔离 级 别 从 最 低 到 最 高 有 如 下 4 种 : 


* 未 提交 读 (read uncommitted) ; 
。 已 提交 读 (read committed); 
。 可 重复 读 (repeatable read) ; 
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* 可 串 行 化 (serializable) 。 

随 着 隔离 级 别 的 提高 ,可 以 更 有 效 地 防止 数据 的 不 一 致 性 。 但 是 ,这 将 降低 事务 的 并 发 
处 理 能 力 ,会 影响 多 用 户 访问 。 隔 离 级 别 也 可 以 通过 编程 方式 进行 设置 。 

(3) 如 何在 事务 中 设置 保存 点 ,保存 点 有 什么 用 途 ? 

答 : 在 事务 中 保存 点 一 般 利用 save transaction 命令 进行 设置 。 设 置 保存 点 可 以 不 用 
回 深 到 事务 的 起 始 位 置 , 而 是 回 深 到 标记 所 在 的 位 置 即 保存 点 ,以 提高 事务 执行 的 效率 。 

(4) 什么 是 死 锁 ,哪些 方法 可 以 解除 死 锁 ? 

答 : 死 锁 是 指 事务 永远 不 会 释放 它们 所 占用 的 资源 , 死 锁 中 的 两 个 事务 都 将 无 限期 

MySQL 能 够 自动 检测 死 锁 循环 ,并 选择 一 个 会 话 作 为 死 锁 中 放弃 的 一 方 ,通过 终止 该 
事务 来 打 断 死 锁 。 被 终止 的 事务 发 生 回 深 , 并 返回 给 连接 一 个 错误 消息 。 

默认 情况 下 : InnoDB 存储 引擎 一 旦 出 现 锁 等 待 超时 异常 ,InnoDB 存储 引擎 既 不 会 提 
交 事 务 ,也 不 会 回 深 事 务 , 而 这 是 十 分 危险 的 。 一 旦 发 生 锁 等 待 超时 异常 ,应 用 程序 应 该 自 
定义 错误 处 理 程序 ,由 程序 开发 人 员 选 择 进一步 提交 事务 ,还 是 回 深 事 务 。 

在 InnoDB 的 事务 管理 和 锁定 机 制 中 ,有 专门 用 于 检测 死 锁 的 机 制 。 当 检测 到 死 锁 时 ， 
InnoDB 会 选择 产生 死 锁 的 两 个 事务 中 较 小 的 一 个 产生 回 滚 ,而 让 另外 一 个 较 大 的 事务 成 功 
完成 。 需 要 注意 的 是 ,如 果 在 产生 死 锁 的 场景 中 涉及 不 止 InnoDB 存储 引擎 时 ,InnoDB 是 
检测 不 到 该 死 锁 的 ,这 时 就 只 能 通过 锁定 超时 限制 来 解决 该 死 锁 了 。 

(5) 简 述 MySQL 中 锁 的 粒度 及 锁 的 常见 类 型 。 

锁 的 粒度 是 指 锁 的 作用 范围 。 锁 的 粒度 可 以 分 为 服务 器 级 锁 (server-level locking) 和 
存储 引擎 级 锁 (storage-engine-level locking), MySQL 支持 很 多 不 同 的 表 类 型 ,而且 对 于 
不 同 的 类 型 ,锁定 机 制 也 是 不 同 的 。 在 MySQL 中 有 三 种 锁定 机 制 。 

(D 表 锁 : 一 个 特殊 类 型 的 访问 ,整个 表 被 客户 锁定 。 根 据 锁定 的 类 型 ,其 他 客户 不 能 
向 表 中 插入 记录 ,甚至 从 中 读数 据 也 受到 限制 。 表 级 锁定 的 类 型 包括 两 种 锁 , 即 读 锁 (read) 
和 写 锁 (write) 。 

© 行 锁 : 行 级 的 锁定 比 表 级 锁定 或 页 级 锁定 对 锁定 过 程 提 供 了 更 精细 的 控制 。 在 这 
种 情况 下 ,只 有 线程 使 用 的 行 是 被 锁定 的 。 表 中 的 其 他 行 对 于 其 他 线程 都 是 可 用 的 。 行 级 
锁定 并 不 是 由 MySQL 提供 锁定 机 制 ,而 是 由 存储 引擎 自己 实现 的 ,其 中 InnoDB 的 锁定 机 
制 就 是 行 级 锁定 。 行 级 锁定 的 类 型 包括 三 种 : 排他 锁 、 共 享 锁 和 意向 锁 。 

© 页 锁 : MySQL 将 锁定 表 中 的 某 些 行 ( 称 为 页 )。 被 锁定 的 行 只 对 锁定 最 初 的 线程 是 
可 行 的 。 

3. 上 机 练习 题 (本 题 利用 teaching 数据 库 中 的 表 进 行 操作 ) 

(1) 创建 存储 过 程 up_score, 实 现在 score 表 上 执行 update 语句 的 事务 ,并 执行 存储 过 

答 : 代码 和 运行 结果 如 下 : 

mysql > delimiter // 

mysql» create procedure up score () 


一 > begin 
一 > start transaction; 


—> update score 
-> set daily = 99, final = 99 
一 > where studentno = '18125121107' and courseno = 'c05109'; 
一 > select * from score 
一 > where studentno = '18125121107' and courseno = 'c05109'; 
一 > commit ; 
-» end // 
Query OK, 0 rows affected (0.04 sec) 
mysql? delimiter ; 
mysql > call up score (); 





4-------- +- + 
| studentno | courseno | daily | final | 
4--------- 4-------- 4----- 二 一 一 一 一 十 
| 18125121107 | c05109 | 99.0 | 99.0 | 
4--------- 4-------- 4----- 二 一 一 一 一 十 


1 row in set (0.04 sec) 
Query OK，0 rows affected (0.34 sec) 


(2) 定义 一 个 事务 ,向 course 表 中 添加 一 条 记录 ,并 设置 保存 点 。 然 后 再 删除 该 记录 ， 
并 回 滚 到 事务 的 保存 点 ,提交 事务 。 
答 : 代码 和 运行 结果 如 下 : 


mysql > delimiter // 
mysql» create procedure insert cno() 
一 > begin 
一 > start transaction; 
-> insert into course 
-> values('c05199', 'MySQL', Jf, 48,12,7); 
一 > savepoint spcno mysql; 
一 > delete from course 
一 > where courseno = 'c05199'; 
一 > rollback work to  savepoint spcno mysql; 
一 > select * from course where courseno = 'c05199'; 
一 > commit ; 
-» end // 
Query OK, 0 rows affected (0.03 sec) 
mysql» delimiter ; 
mysql» call insert cno(); 


4------- 4---—4----- 4----- +----+----+ 
| courseno | cname | type | period | exp | term | 
+------- +----+----- 4----- + 一 一 一 一 + 一 一 一 一 + 
| c05199 | MySQL | 必修 | 48112| 7| 

4------- 4---—4----- 4--——- +----+----+ 


1 row in set (0.03 sec) 
Query OK, 0 rows affected (0.08 sec) 


(3) 创建 事务 ,练习 在 student 表 上 进行 查询 、 插 入 和 更 新 操作 。 
答 : 代码 和 运行 结果 如 下 : 


mysql > delimiter // 
mysql» create procedure student iud() 
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一 > begin 
一 > start transaction; 
一 > select studentno, sname 
-> from student 
-> where studentno = '18135222201'; 
-> insert into student values('1928261001', f) fEXE', 
A '1r', 1999 - 09 — 09', 799, 1398909876 ', 'sdy(2163. com") ; 
-> update student set sname = ' 孙 释 平 ' 
-> where studentno = '19123567897'; 
一 > commit ; 
-» end // 
Query OK, 0 rows affected (0.02 sec) 
mysql > delimiter ; 
mysql > call student. iud(); 


4---------- 4------ * 
| studentno | sname | 
+ 一 一 一 一 一 一 一 一 一 一 4------ * 
| 18135222201 | 凌 浩 风 | 
+ 一 一 一 一 一 一 一 一 一 一 4------ * 


1 row in set (0.00 sec) 

Query OK, 0 rows affected (0.08 sec) 
mysql > select studentno, sname, birthdate 

一 > from student where sname like 'jj % '; 

4---------- 4------ 4----------- * 

| studentno | sname | birthdate | 

4---------- 4------ 4----------- * 

| 19123567897 | 孙 释 平 2002 - 08 - 04 | 

| 1928261001 | 孙 释 远 | 1999 - 09 - 09 | 

*---------- 4------ 4----------- * 

2 rows in set (0.01 sec) 


(4) 将 course 表 中 课程 号 为 608123 的 课程 名 称 改 为 "PHP 语言 ”, 并 提交 该 事务 。 
答 : 代码 和 运行 结果 如 下 : 


mysql > delimiter // 
mysql» create procedure up cname() 
-> begin 
一 > start transaction; 
-> update course set cname = 'PHP 语言 ' 
一 > where courseno = 'c08123'; 
一 > commit; 
一 > select * from course where courseno = 'c08123'; 
-» end // 
Query OK, 0 rows affected (0.01 sec) 
mysql» delimiter ; 
mysql» call up cnane(); 


4------- 4------- 4----- +------ +---+----+ 
| courseno | cname | type | period | exp | term | 
+------- 4------- 4----- 4---——- +---+----+ 
| c08123 | PHP 语 言 | 必修 | — 40| 01 51 

4------- 4------- 4----- + 一 一 一 一 一 一 + 一 一 一 + 一 一 一 一 + 


1 row in set (0.03 sec) 
Query OK, 0 rows affected (0.06 sec) 
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10.1 教学 要 求 


10.1.1 基本 要 求 


(1) 了 解 MySQL 权限 系统 的 工作 机 制 ,了 解 MySQL 数据 库 中 各 表 的 功能 。 
(2) 掌握 MySQL 权限 系统 的 工作 过 程 。 

G) 掌握 普通 用 户 的 创建 、 使 用 和 删除 的 命令 。 

(4) 掌握 MySQL 命令 的 使 用 格式 和 执行 过 程 。 

(5) 了 解 利用 图 形 工具 管理 用 户 的 过 程 。 

(6) 了 解 MySQL 的 权限 类 型 。 

(7) 掌握 授权 管理 ,收回 、 查 看 和 限制 权限 的 基本 操作 。 

(8) 了 解 MySQL 数据 库 安全 的 常见 问题 。 

(9) 了 解 确保 MySQL 安全 的 注意 事项 。 


10.1.2 重点 与 难点 


1. 本 章 重 点 

(1) MySQL 权限 系统 的 工作 过 程 。 

(2) 普通 用 户 的 创建 .使 用 和 删除 。 

(3) 掌握 MySQL 命令 的 使 用 格式 和 执行 过 程 。 
(4) 掌握 管理 访问 权限 的 grant 和 revoke 命令 格式 .应 用 方法 和 主要 用 途 。 
2. 本 章 难 点 

OD MySQL 权限 系统 的 工作 过 程 。 

(2) 普通 用 户 的 创建 ,使 用 和 删除 。 

(3) MySQL 命令 的 使 用 格式 和 执行 过 程 。 

(4) 授权 管理 ,收回 、 查 看 和 限制 权限 的 基本 操作 。 
(5) MySQL 数据 库 安全 常见 问题 。 


10.2 习题 参考 答案 


1. 选择 题 
(1) 在 MySQL 中 ,可 以 使 用 语句 来 为 指定 数据 库 添加 用 户 。 
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A. revoke B. grant C. insert D. create 
(2) MySQL 中 存储 用 户 全 局 权限 的 表 是 

A. tables_priv B. procs_priv C. columns_priv D. user 
(3) 下 列 命令 中 ， 命令 用 于 撤销 MySQL 用 户 对 象 权限 。 

A. revoke B. grant C. deny D. create 


(4) 给 名 字 是 liping 的 用 户 分 配对 数据 库 teaching 中 的 student 表 的 查询 和 插入 数据 
权限 的 语句 是 
A. grant select,insert on teaching. student for 'liping'@ 'localhost' 
B. grant select.insert on teaching. student to 'liping'(2 'localhost' 
C. grant 'liping'@ 'localhost' to select, insert for teaching. student 


D. grant 'liping'(? localhost' to teaching. student on select, insert 


(5) 修改 自己 的 MySQL 服务 器 密码 的 命令 是 。 
A. mysql B. grant 
C. set password D. change password 





本 题 答案 :CD ABC 











2. 思考 题 

(1) 简 述 MySQL 在 对 象 上 进行 权限 设置 时 ,用 户 和 权限 的 关系 。 

答 : 对 象 权限 表示 对 特定 的 数据 库 对 象 ( 表 、 视 图 .字段 和 存储 过 程 ) 的 操作 权限 , 它 决 
定 了 能 对 表 、 视 图 等 数据 库 对 象 执 行 的 操作 。 在 对 象 上 进行 权限 设置 时 ,用 户 可 以 单独 设置 
权限 ,但 需要 防止 权限 设置 冲突 。 

(2) 在 MySQL 中 可 以 授予 的 权限 有 哪 几 个 层次 ? 

答 : 在 MySQL 中 可 以 授予 的 权限 有 如 下 权限 组 : 列 权 限 、 表 权限 、 数 据 库 权限 和 用 户 
权限 。 

(3) 在 MySQL 的 权限 授予 语句 中 ,可 用 于 指定 权限 级 别 的 值 有 哪 几 类 格式 ? 

答 : 在 MySQL 的 权限 授予 语句 中 ,可 用 于 指定 权限 级 别 的 值 有 下 面 几 类 格式 。 

tox : 表示 当前 数据 库 中 的 所 有 表 。 

。 x. o: 表示 所 有 数据 库 中 的 所 有 表 。 
db name. * ; 表示 某 个 数据 库 中 的 所 有 表 。 
db name. tbl_name: 表示 某 个 数据 库 中 的 某 个 表 或 视图 ,db_name 指定 数据 库 名 ， 
tbl_name 指定 表 名 或 视图 名 。 
table name; 表示 某 个 表 或 视图 ,table_name 指定 表 名 或 视图 名 。 
db name. routine name; 表示 某 个 数据 库 中 的 某 个 存储 过 程 或 函数 ,routine_name 
指定 存储 过 程 名 或 函数 名 。 

(4) 在 数据 加 密 过 程 中 ,password() 函 数 有 什么 作用 ? 

答 : 当 使 用 set password,insert 或 者 update 指定 账户 的 密码 时 ,必须 用 password O PRI 
数 对 它 进行 加 密 。 因 为 user 表 以 加 密 方 式 保存 密码 ,而 不 是 明文 。 当 用 户 使 用 该 密码 连接 
服务 器 时 ,连接 使 用 的 密码 值 将 被 加 密 , 并 同 保存 在 user 表 中 的 密码 进行 比较 。 因 此 比较 


将 失败 ,服务 器 会 拒绝 连接 。 唯 一 的 特例 是 如 果 密 码 为 空 , 则 不 需要 使 用 passwordO 。 
3. 上 机 练习 题 (本 题 利用 teaching 数据 库 进 行 操 作 ) 
(1) 使 用 grant 语句 创建 一 个 新 用 户 ex_user, 密 码 为 pass123。 用 户 ex user 对 当前 数 
据 库 中 的 所 有 表 有 查询 、 插 入 权限 ,并 授予 grant 权限 。 
B: 代码 和 运行 结果 如 下 : 
mysql» grant select, insert on * to 'ex user'@ 'localhost' 
-> identified by 'pass123' 
一 > with grant option; 
Query OK, 0 rows affected, 1 warning (0.22 sec) 


(2) 利用 grant 语句 将 teaching 数据 库 中 student 表 的 delete 权限 授予 用 户 ex. user, 
答 : 代码 和 运行 结果 如 下 : 
mysql > grant delete on teaching. student 

-> to 'ex_user'@ 'localhost'; 

Query OK, 0 rows affected (0.09 sec) 

(3) 收回 ex user 用 户 对 teaching 数据 库 中 student 表 的 delete 权限 。 
答 : 代码 和 运行 结果 如 下 : 
mysql > revoke delete on teaching. student 


-> from ex user(d localhost; 
Query OK, 0 rows affected (0.02 sec) 


(4) 使 用 revoke 语句 收回 ex. user 用 户 的 所 有 权限 ,包括 grant 权限 。 
答 : 代码 和 运行 结果 如 下 : 
mysql» revoke all privileges, grant option 


-> from ex user(à localhost; 
Query OK, 0 rows affected (0.02 sec) 


(5) 假定 当前 系统 中 不 存在 用 户 swming, 请 编写 一 段 SQL 语句 ,要 求 创 建 这 个 新 用 
户 , 并 为 其 设置 对 应 的 系统 登录 口令 “my123”, 同 时 授予 该 用 户 在 数据 库 teaching 的 表 
course 中 拥有 select 和 update 的 权限 。 
答 : 代码 和 运行 结果 如 下 : 
mysql» grant select, update on teaching. course to 'swning'(9 'localhost' 
-> identified by 'my123'; 
Query OK, 0 rows affected, 1 warning (0.04 sec) 


—-w 


^ dé 
/w 


y 
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第 11 章 备份 与 恢复 





11.1 教学 要 求 


11.1.1 基本 要 求 


(1) 了 解数 据 库 备份 的 原因 和 分 类 标准 。 

(2) 了 解数 据 库 恢复 时 需要 注意 的 时 机 问题 。 
(3) 掌握 数据 库 备 份 的 基本 格式 和 基本 操作 。 
(4) 掌握 数据 库 还 原 的 基本 格式 和 基本 操作 。 
G) 掌握 表 数 据 的 导入 与 导出 基本 操作 。 

(6) 了 解数 据 库 迁 移 的 各 种 方法 。 


11.1.2 重点 与 难点 


1. 本 章 重 点 

(1) 使 用 mysqldump 命令 备份 。 

(2) 直接 复制 整个 数据 库 目 录 。 

(3) 使 用 mysqlhotcopy 工具 快速 备份 。 
(4) 利用 MySQL 命令 恢复 数据 。 

(5) 用 source 恢复 表 和 数据 库 。 

(6) 用 select...into outfile 导出 文件 。 

(7) 用 MySQL 命令 导出 文本 文件 。 

(8) 用 load data infile 方式 导入 文本 文件 。 
2. 本 章 难点 

(1) 直接 复制 整个 数据 库 目录 。 

(2) 使 用 mysqlhotcopy 工具 快速 备份 。 
(3) 数据 库 迁 移 的 各 种 方法 。 

(4) 用 select...into outfile 导出 文件 。 

(5) Hi load data infile 方式 导入 文本 文件 。 


11.2 习题 参考 答案 


1. 选择 题 
(1) 在 数据 库 系 统 生 命 周 期 中 可 能 发 生 的 灾难 不 包括 A 

A. 系统 故障 B. 事务 故障 C. 掉 电 故障 D. 介质 故障 
(2) 按 备份 时 服务 器 是 否 在 线 划分 不 包括 备份 。 

A. 热 备 份 B. 完全 备份 C. V & D. 温 备 份 
(3) 还 原 数 据 库 时 ,首先 要 进行 操作 。 

A. 创建 数据 表 备份 B. 创建 完整 数据 库 备 份 

C. 创建 冷 设备 D. 删除 最 近 事 务 日 志 备 份 
(4) 创建 数据 库 文件 或 文件 组 备份 时 ,首先 要 进行 操作 。 

A. 创建 事务 日 志 D. 创建 完整 数据 库 备份 

C. 创建 温 备 份 D. 删除 差异 备份 
(5) 下 面 故 障 发 生 时 ， 需要 数据 库 管理 员 进行 手工 操作 恢复 。 

A. 停电 B. 误 删 表 数 据 C. 死 锁 D. 操作 系统 错误 








本 题 答 案 : CBBBB 








2. 思考 题 

(1) 为 什么 在 MySQL 中 需要 进行 数据 库 的 备份 与 恢复 操作 ? 

答 : 备份 和 恢复 的 目的 就 是 将 数据 库 中 的 数据 进行 导出 ,生成 副本 ,然后 在 系统 发 生 
故障 后 能 够 恢复 全 部 或 部 分 数据 。 数 据 备份 就 是 制作 数据 库 结构 、 对 象 和 数据 的 拷贝 ， 
以 便 在 数据 库 遭 到 破坏 时 ,或 因 需 求 改变 而 需要 把 数据 还 原 到 改变 以 前 时 能 够 恢复 数据 
库 。 数 据 恢复 就 是 指 将 数据 库 备 份 加 载 到 系统 中 。 数 据 备份 和 恢复 可 以 用 于 保护 数据 
库 的 关键 数据 。 在 系统 发 生 错 误 或 者 因 需 求 改变 时 ,利用 备份 的 数据 可 以 恢复 数据 库 中 
的 数据 。 

(2) MySQL 数据 库 备 份 与 恢复 的 常用 方法 有 哪些 ? 

答 : MySQL 数据 库 备份 与 恢复 的 常用 方法 有 : 

。 使 用 SQL 语句 备份 和 恢复 表 数 据 。 

* 使 用 MySQL 客户 端 实 用 程序 备份 和 恢复 数据 。 

。 使 用 MySQL 图 形 界面 工具 备份 和 恢复 数据 。 

。 直接 复制 。 

G) 使 用 直接 复制 方法 实现 数据 库 备 份 与 恢复 时 ,需要 注意 哪些 事项 ? 

答 : 使 用 直接 从 一 个 MySQL 服务 器 复制 文件 到 另 一 个 服务 器 的 方法 ,需要 特别 注意 
以 下 两 点 : 

CD. 两 个 服务 器 必须 使 用 相同 或 兼容 的 MySQL 版 本 。 

@ 两 个 服务 器 必须 硬件 结构 相同 或 相似 .除非 要 复制 的 表 使 用 MyISAM 存储 格式 ,这 
是 因为 这 种 表 可 以 为 在 不 同 的 硬件 体系 中 共享 数据 提供 保证 。 
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(4) 进行 数据 库 还 原 应 该 注意 哪些 问题 ? 

答 : 在 还 原 数 据 库 的 时 候 , 应 该 注意 如 下 问题 : 

D 了 解 执行 的 备份 方法 的 类 型 和 备份 是 否 存在 。 

O 确认 备份 文件 包含 要 还 原 的 备份 ,并 确认 备份 是 否 有 效 。 

@ 如 果 使 用 完整 数据 库 备 份 来 还 原 数据 库 , MySQL 重新 创建 这 些 数据 库 文件 和 所 有 
的 数据 库 对 象 ,如 果 使 用 差异 数据 库 备 份 来 恢复 , 则 可 以 恢复 最 近 的 差异 数据 库 备份 。 

CD. 在 数据 库 还 原 过 程 中 确保 要 还 原 的 数据 库 没 有 打开 的 连接 。 因 为 在 进行 还 原 的 时 
候 不 允许 有 连接 到 数据 库 的 连接 。 

(5) 备份 数据 库 的 时 机 如 何 选择 ? 

答 : 备份 数据 库 的 时 机 取决 于 可 接受 的 数据 丢失 量 和 数据 库 活 动 的 频繁 程度 。 可 以 从 
下 列 几 方面 考虑 备份 的 时 机 。 

。 创建 数据 库 或 为 数据 库 填充 了 数据 以 后 ,用 户 应 该 备份 数据 库 。 

。 创建 索引 后 备份 数据 库 。 

。 清理 事务 日 志 后 备份 数据 库 。 当 执行 了 清理 事务 日 志 的 语句 后 ,应 该 备份 数据 库 。 

在 清理 之 后 ,事务 日 志 将 不 包含 数据 库 的 活动 记录 ,也 不 能 用 来 还 原 数 据 库 。 

。 执行 了 无 日 志 操作 后 也 应 该 备份 数据 库 。 

3. 上 机 练习 题 ( 本 题 利用 teaching 数据 库 进 行 操作 ) 

(1) 使 用 mysqldump 命令 备份 数据 库 teaching 中 的 所 有 表 。 

答 : 代码 和 运行 结果 如 下 : 

mysqldump - u root - p teaching > d:/bak/teachingbak. sql 

Enter password: x** 

(2) 使 用 source 命令 将 备份 文件 teachingbak. sql 恢复 到 数据 库 中 。 

答 : 代码 和 运行 结果 如 下 : 

mysql > source d:\bak\teachingbak. sql 

Query OK, 0 rows affected (0.00 sec) 


Query OK, 0 rows affected (0.00 sec) 


(3) 使 用 mysqldump 命令 备份 数据 库 中 的 score 表 。 
答 : 代码 和 运行 结果 如 下 : 


mysqldump — u root - p teaching course > d: /bak/score. sql 
Enter password: ****** 


(4) 删除 score 表 的 数据 ,用 source 命令 恢复 。 
答 : 代码 和 运行 结果 如 下 : 


# 尝试 删除 score 表 的 数据 
mysql» use teaching; 
Database changed 
mysql» delete from score; 
Query OK, 26 rows affected (0.11 sec) 
# 利 用 放 在 "d:/bak" 路 径 下 score 的 备份 文件 score. sal, 使 用 source 命令 把 备份 好 的 文件 导入 进行 恢复 


mysql > source d: /bak/score. sql; 
Query OK, 0 rows affected (0.00 sec) 


Query OK, 26 rows affected (0.03 sec) 
Records:26 Duplicates: 0 Warnings: 0 


Query OK, 0 rows affected (0.00 sec) 


(5) 使 用 MySQL 命令 将 teaching 数据 库 中 的 course 表 中 的 记录 导出 到 文本 文件 。 

答 : 代码 和 运行 结果 如 下 : 

mysql -uroot -p —- execute = "select * from course;"teaching > d: /bak/teach. txt 

Enter password: x 

(6) 用 备份 好 的 teach. txt 文件 恢复 course 表 数 据 。 为 避免 主键 冲突 ,要 用 replace 
into table 直接 将 数据 进行 替换 来 恢复 数据 。 

答 : 代码 和 运行 结果 如 下 : 

mysql» load data infile 'd:/bak/teach. txt' 

-» replace into table course ; 


Query OK, 13 rows affected (0.03 sec) 
Records:26 Duplicates: 0 Warnings: 0 
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第 12 章 MySQL 性 能 优化 





12.1 教学 要 求 


12.1.1 基本 要 求 


(1) 了 解数 据 库 优化 的 含义 和 查看 数据 库 性 能 参数 的 方法 。 

(2) 掌握 优化 查询 的 方法 .优化 数据 库 结构 的 方法 和 优化 MySQL 服务 器 的 方法 。 
(3) 了 解 使 用 索引 优化 查询 的 方法 。 

(4) 了 解 在 MySQL 中 分 析 查 询 效率 的 方法 。 

(5) 掌握 在 MySQL 中 应 用 高 速 缓存 提高 查询 性 能 的 方法 。 

(6) 掌握 如 何在 多 表 查 询 中 提高 查询 性 能 。 

(7) 掌握 在 MySQL 中 使 用 临时 表 提 高 优化 查询 效率 的 方法 。 


12.1.2 重点 与 难点 


1. 本 章 重 点 

(1) MySQL 性 能 优化 的 主要 方法 。 
(2) 优化 查询 语句 的 使 用 方法 。 
(3) 索引 对 查询 速度 的 影响 。 
(4) 使 用 索引 优化 查询 的 方法 。 
(5) 优化 数据 库 结构 的 方法 。 
(6) 优化 慢 查 询 的 方法 。 

CD 查询 高 速 缓 存 的 过 程 。 

2. 本 章 难 点 

(1) 优化 查询 语句 的 使 用 方法 。 
(2) 索引 对 查询 速度 的 影响 。 
(3) 使 用 索引 优化 查询 的 方法 。 
(4) 优化 数据 库 结构 的 方法 。 
(5) 查询 高 速 缓存 的 过 程 。 


12.2 习题 参考 答案 


1. 选择 题 
(1) 使 用 Explain 语句 可 对 语句 的 执行 效果 进行 分 析 , 通 过 分 析 提 出 优化 运行 
速度 的 方法 。 
A. select B. insert C. delete D. create 
D 多 列 索 引 在 表 的 多 个 字段 上 创建 一 个 索引 。 只 有 查询 条 件 中 使 用 了 这 些 字段 中 
的 时 ,索引 才 会 被 正常 使 用 。 
A. 最 后 1 个 字段 B. 第 2 个 字段 C. 第 1 个 字段 D. 所 有 字段 
(3) 使 用 analyze table 分 析 表 的 过 程 中 ,数据 库 系 统 会 对 表 加 一 个 。 在 分 析 
期 间 , 只 能 读 取 表 中 的 记录 ,不 能 更 新 和 插入 记录 。 
A. 排他 锁 B. 只 读 锁 C. 读 写 锁 D. 意向 锁 
(4) 若 有 某 些 查询 经 常 涉及 多 表 连 接 ,可 以 视 情 况 将 这 些 字 段 建立 一 个 来 进 
行 查询 和 统计 ,提高 查询 效率 。 
A. 查询 表 B. 排序 表 C. 中 间 表 D. 子 查询 
(5) 为 了 解决 插入 记录 时 ， 过 程 会 降低 插入 记录 速度 的 情况 ,在 插入 记录 之 前 
可 以 先 禁用 索引 。 等 到 记录 都 插 和 人 完毕 后 再 开启 索引 。 
A. 索引 B. 排序 C. 查询 D. 插入 





本 题 答案 : AC BCA 











2. 思考 题 

(1) 如 何 使 用 查询 缓存 区 ? 

答 : Query. cache. type: 表示 查询 缓冲 区 的 开启 状态 。0 表示 关闭 ,1 表示 开启 。 查 询 
缓冲 区 主要 是 为 了 提高 经 常 执行 相同 的 查询 操作 的 速度 ,但 是 , 另 一 方面 查询 缓冲 区 也 无 形 
中 增加 了 系统 的 开销 ,所 以 有 时 为 减少 系统 的 开销 ,也 可 以 关闭 查询 缓冲 区 。 如 果 设 置 
Query_cache_type 二 1, 所 有 查询 都 将 使 用 查询 缓冲 区 。 

如 果 设 置 Query_cache_type 二 0, 则 所 有 查询 不 使 用 查询 缓冲 区 。 但 不 会 导致 MySQL 
释放 query cache size 配置 的 缓冲 区 内 存 。 如 果 要 禁用 查询 缓存 ,可 以 设置 query_cache_ 
size 一 0, 禁 用 查询 缓存 后 ,将 没有 明显 的 开销 。 

(2) 为 什么 查询 语句 中 的 索引 有 时 会 没有 发 挥 作用 ? 

答 : 在 查询 过 程 中 使 用 索引 ,势必 会 提高 数据 库 的 查询 效率 ,应 用 索引 来 查询 数据 库 中 
的 内 容 , 可 以 减少 查询 的 记录 数 , 从 而 达到 查询 优化 的 目的 。 

一 般 情况 下 ,使 用 索引 可 以 提高 查询 的 速度 ,但 如 果 MySQL 语句 使 用 不 恰当 的 话 , 索 
引 将 无 法 发 挥 它 应 有 的 作用 。 如 果 在 一 个 表 中 创建 了 多 列 的 复合 索引 ,只 有 查询 条 件 中 使 
用 了 这 些 字段 的 第 一 个 字段 时 ,索引 才 会 使 用 。 

如 果 一 个 查询 ,没有 使 用 索引 进行 查询 , 则 使 用 explain 命令 分 析 查 询 时 ,type 为 all 表 
示 要 对 表 进 行 全 扫描 。 
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(3) 什么 是 慢 查 询 ? 形成 慢 查 询 的 原因 有 哪些 ? 

答 : MySQL 将 执行 时 间 长 的 查询 语句 称 为 慢 查 询 。MySQL 利用 long query. time 来 
定义 慢 于 多 少 秒 的 才 算 “ 慢 查 询 ”, 系统 默认 是 10 秒 。 并 可 以 通过 设置 slow_query_log 参 
数 决 定 是 否 打开 日 志 记 录 慢 查询 ,on 表示 打开 ,off 表示 关闭 。 

形成 慢 查 询 的 原因 可 以 从 如 下 几 个 方面 去 了 解 : 

O 了 解 业务 方 使 用 场景 ,查看 查询 字段 是 否 没有 索引 或 者 没有 用 到 索引 (这 是 查询 慢 
最 常见 的 问题 ,是 程序 设计 的 缺陷 ) 。 

@ 硬件 环境 问题 。 内 存 不 足 , 网 络 速度 慢 ,1/O 吞吐 量 小 ,形成 了 瓶颈 效应 。 

@ 有 没有 创建 计算 列 导致 查询 不 优化 ; 查询 语句 不 好 ,没有 优化 ,是 否 返 回 了 不 必要 
的 数据 ; 查询 出 的 数据 量 过 大 (可 以 采用 多 次 查询 ,其 他 的 方法 降低 数据 量 ) 。 

CD 利用 explain 查看 执行 计划 ,是 否 与 预期 一 致 (从 锁定 记录 较 少 的 表 开 始 查询 ) 。 

© 是 否 形成 锁 或 者 死 锁 (这 也 是 查询 慢 最 常见 的 问题 ,是 程序 设计 的 缺陷 ) 。 

© 利用 sp lock,sp who 等 参数 查看 活动 的 用 户 ,是 否 存在 读 写 竞 争 资源 。 

(4) 如 何 从 优化 查询 的 角度 进行 表 字 段 的 设计 ? 

答 : 在 设计 数据 表 时 应 优先 考虑 使 用 特定 字段 长 度 , 后 考虑 使 用 变 长 字段 ,如 在 用 户 创 
建 数据 表 时 ,考虑 创建 某 个 字段 类 型 为 varchar 而 设置 其 字段 长 度 为 255, 但 是 在 实际 应 用 
时 ,该 用 户 所 存储 的 数据 根本 达 不 到 该 字段 所 设置 的 最 大 长 度 ,命令 外 如 设置 用 户 性 别 的 字 
段 ,往往 可 以 用 M 表示 男性 ,F 表示 女性 ,如 果 给 该 字段 设置 长 度 为 varchar(50), 则 该 字段 
占用 了 过 多 列 宽 ,这 样 不 仅 浪费 资源 ,也 会 降低 数据 表 的 查询 效率 。 适 当 调整 列 宽 不 仅 可 以 
减少 磁盘 空间 ,同时 也 可 以 使 数据 在 进行 处 理 时 产生 的 1/O 过 程 减少 。 将 字段 长 度 设置 成 
其 可 能 应 用 的 最 大 范围 可 以 充分 地 优化 查询 效率 。 

3. 上 机 练习 题 (本 题 利用 teaching 数据 库 中 的 表 进 行 操作 ) 

(1) 使 用 explain 语句 来 分 析 一 个 查询 语句 。 

答 : 代码 和 运行 结果 如 下 : 





mysql» explain select * from student\G 
汪汪 闪闪 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 l, DOW 关 关 关 尖 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 关 
id: 1 
select_type: SIMPLE 
table: student 
partitions: NULL 
type: ALL 
possible keys: NULL 
key: NULL 
key len: NULL 
ref: NULL 
rows: ll 
filtered: 100.00 
Extra: NULL 
1 row in set, 1 warning (0.00 sec) 


(2) 分 析 查 询 语句 ,对 比 不 使 用 索引 和 使 用 索引 的 情况 。 
答 : 代码 和 运行 结果 如 下 : 


# 分 析 未 使 用 索引 时 的 查询 情况 
mysql» explain select * from course where cname = ' 软 件 工程 \G 
GORGCORGORGORGOOOOXOOOOGOOOE l, TOW F I I IE FE E FE FE E EE EEEE 
id: 1 
select_type: SIMPLE 
table: course 
partitions: NULL 
type: ALL 
possible_keys: NULL 
key: NULL 
key_len: NULL 
ref: NULL 
rows: 13 
filtered: 10.00 
Extra: Using where 
1 row in set, 1 warning (0.00 sec) 
mysql> create index index cname on course(cname); -- 创建 索引 
Query OK, 0 rows affected, 1 warning (0.56 sec) 
Records: 0 Duplicates: 0 Warnings: 1 
# 分 析 使 用 索引 时 的 查询 情况 
mysql» explain select * from course where cname = ' 软 件 工程 \G 
OOKOCOOGCROOIOOXGOOOOOOOOEX. L, TOW FFE IE IEE EIE JE E AE IEE JE FE EE JEEE E 
id: 1 
select_type: SIMPLE 
table: course 
partitions: NULL 
type: ref 
possible_keys: index_cname 
key: index_cname 
key_len: 12 
ref: const 
rows: 1 
filtered: 100. 00 
Extra: NULL 
1 row in set, 1 warning (0.00 sec) 


CD 利用 explain 语句 执行 查询 命令 .应 用 like 关键 字 , 且 匹配 字符 串 中 含有 的 百 分 


号 “%”。 
答 : 代码 和 运行 结果 如 下 : 


mysql» explain select * from course where cname like '% 软件 \G 
GOXOGOXOOEOXOOXOXOEXOGOEXGE €. l, DOW 闪闪 关 关 关 尖 闪闪 关 关 关 关 关 关 闪闪 关 关 关 关 
id: 1 
select type: SIMPLE 
table: course 
partitions: NULL 
type: ALL 
possible keys: NULL 
key: NULL 
key len: NULL 
ref: NULL 
rows: 13 
filtered: 11.11 
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Extra: Using where 
1 row in set, 1 warning (0.00 sec) 
mysql» explain select * from course where cname like ' 软 件 $ '\G 
GORGORGOROGEROUOOERGOORRGOCE l, TOW F33 IEE E AE F 3E IEE E FE FEE EE E ERE 
id: 1 
select_type: SIMPLE 
table: course 
partitions: NULL 
type: range 
possible_keys: index_cname 
key: index_cname 
key_len: 12 
ref: NULL 
rows: 1 
filtered: 100.00 
Extra: Using index condition 
1 row in set, 1 warning (0.00 sec) 


说 明 : 

从 上 面 两 个 运行 结果 中 可 以 看 出 ,cname 列 使 用 了 索引 ,都 与 like 关键 字 进 行 匹 配 。 如 
果 匹 配 字符 (% 或 _) 在 字符 串 的 后 面 ,索引 在 其 中 起 作用 ,如 第 一 种 情况 ,匹配 字符 (% 或 _) 
在 字符 串 的 前 面 , 索 引 将 不 起 作用 ,type 值 为 all 级 , 即 对 表 进 行 全 扫描 ,检查 的 行 数 为 13 
行 ,虽然 符合 条 件 的 记录 行为 1 行 。 

对 于 第 二 种 情况 ,type 值 为 range 级 ,因为 有 1 条 符合 条 件 的 记录 ,所 以 rows 参数 值 为 
1, 检 查 的 行 数 只 有 1 行 。 

由 此 可 以 知道 ,使 用 like 关键 字 和 通配符 的 做 法 虽然 简单 、 易 懂 , 但 却 也 是 以 牺牲 系统 
性 能 为 代价 的 。 

(4) 执行 analyze table 语句 分 析 course X. 

答 : 代码 和 运行 结果 如 下 : 

mysql» analyze table course; 


4-------------- 4------ 4-------- 4-------- * 
| Table | Op | Msg type | Msg text 


| teaching.course | analyze | status | OK | 
4-------------- 4------ 4-------- 4-------- * 
1 row in set (0.10 sec) 


C5) 执行 check table 语句 检查 表 course. 
答 : 代码 和 运行 结果 如 下 : 


mysql» check table course; 


| Table | op | Msg type | Msg text | 
4-------------- + 一 一 一 一 一 + 一 一 一 一 一 一 一 4-------- * 
| teaching.course | check | status | OK | 
4-------------- + 一 一 一 一 一 4------- 4-------- * 
1 row in set (0.03 sec) 
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13.1 教学 要 求 


1.1 基本 要 求 


(OD 了 解 MySQL 日 志文 件 的 分 类 和 作用 。 

(2) 掌握 启用 、 设 置 .查看 和 删除 错误 日 志 的 基本 操作 。 

(3) 掌握 启用 、 查 看 ,清理 和 暂时 停止 二 进 制 日 志 的 基本 操作 。 
(4) 掌握 利用 二 进 制 日 志 恢 复数 据 库 的 操作 。 

(5) 了 解 通用 查询 日 志 的 管理 。 

(6) 掌握 启用 、 操 作 和 删除 慢 查询 日 志 的 基本 操作 。 


1.2 重点 与 难点 


1. 本 章 重 点 

CD 二 进 制 日 志 的 启用 、 查 看、 暂停 和 清理 的 基本 操作 。 
(2) 利用 二 进 制 日 志 恢复 数据 库 的 过 程 。 

(3) 错误 日 志 的 启用 、 查 看 和 删除 等 基本 操作 。 

CD 通用 查询 日 志 的 启用 、 查 看 和 删除 等 基本 操作 。 

2. 本 章 难 点 

CD 错误 日 志 的 启用 、 查 看 和 删除 等 基本 操作 。 

(2) 利用 二 进 制 日 志 恢 复数 据 库 的 过 程 。 

(3) 通用 查询 日 志 的 启用 、 查 看 和 删除 等 基本 操作 。 
(4) 设置 错误 日 志 存 取 路 径 的 方法 。 


13.2 习题 参考 答案 


1. 选择 题 

OD MySQL 的 日 志 在 默认 情况 下 ,只 启动 了 的 功能 。 
A. 二 进 制 日 志 B. 错误 日 志 C. 通用 查询 日 志 

(2) MySQL 的 日 志 中 , 除 外 ,其 他 日 志 都 是 文本 文件 。 
A. 二 进 制 日 志 B. 错误 日 志 C. 通用 查询 日 志 


(3) 如 果 很 长 时 间 不 清理 二 进 制 日 志 , 将 会 浪费 很 多 的 磁盘 空间 


MySQL 日 志文 件 管理 


D. 慢 查 询 日 志 


D. 慢 查 询 日 志 
。 删 除 二 进 制 日 志 的 
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方法 不 包括 
A. 删除 所 有 二 进 制 日 志 B. 删除 指定 编号 的 二 进 制 日 志 
C. 根据 创建 时 间 来 删除 二 进 制 日 志 D. 删除 指定 时 刻 的 二 进 制 日 志 
(4) 如 果 数 据 库 遭 到 意外 损坏 ,首先 应 该 使 用 最 近 的 备份 文件 来 还 原 数据 库 , 可 以 使 用 
A. 通用 查询 日 志 B. 错误 日 志 C. 二 进 制 日 志 D. 慢 查询 日 志 





本 题 答案 : BA DC 











2. 思考 题 

(1) MySQL 的 日 志 分 几 类 ,各 有 什么 作用 ? 

答 : 包括 二 进 制 日 志 、 错 误 日 志 、 通 用 查询 日 志和 慢 查询 日 志 4 类 。4 类 日 志文 件 的 具 
体 功 能 如 下 : 

。 二进制 日 志 : 以 二 进 制 文件 的 形式 记录 了 数据 库 中 所 有 更 改 数据 的 语句 ,还 可 以 运 

用 于 复制 操作 。 

。 错误 日 志 : 记录 MySQL 服务 的 启动 .运行 和 停止 mysqld 时 出 现 的 问题 。 

。 通用 查询 日 志 : 记录 用 户 登 录 和 记录 查询 的 信息 。 

。 慢 查询 日 志 : 记录 所 有 执行 时 间 超 过 long. query. time 秒 的 查询 或 不 使 用 索引 的 

查询 。 

(2) 慢 查询 日 志 有 什么 特点 和 作用 ? 

答 : 慢 查询 日 志 的 特点 : 慢 查询 日 志 是 记录 查询 时 长 超过 指定 时 间 的 日 志 。 执 行 时 间 
超过 指定 时 间 的 查询 语句 会 被 记录 到 慢 查 询 日 志 中 。 如 果 查 询 时 间 超 过 了 这 个 时 间 值 ,这 
个 查询 语句 将 被 记录 到 慢 查询 日 志 。 默 认 情 况 下 , 慢 查 询 日 志 功能 是 关闭 的 。 

慢 查 询 日 志 的 作用 : 慢 查询 日 志 主 要 用 来 记录 执行 时 间 较 长 的 查询 语句 。 通 过 慢 查 询 
日 志 , 可 以 找 出 执行 时 间 较 长 ,执行 效率 较 低 的 语句 ,然后 进行 优化 。 如 果 用 户 希 望 查询 哪 
些 查 询 语句 的 执行 效率 低 , 可 以 从 慢 查 询 日 志 中 获得 想 要 的 信息 。 慢 查询 日 志 也 是 以 文本 
文件 的 形式 存储 的 。 可 以 使 用 普通 的 文本 文件 查看 工具 来 查看 。 

(3) 简 述 MySQL 日 志 的 主要 作用 。 

答 : MySQL 日 志 用 来 记录 MySQL 数据 库 的 运行 情况 、 用 户 操 作 和 错误 信息 等 。 当 
MySQL 服务 器 在 某 个 时 间 出 现 异常 时 ,异常 信息 也 会 被 记录 到 日 志文 件 中 。 日志 文件 可 
以 为 MySQL 管理 和 优化 提供 必要 的 信息 。 

如 果 MySQL 数据 库 系 统 意 外 停止 服务 ,可 以 通过 错误 日 志 查 看 出 现 错误 的 原因 。 并 
且 可 以 通过 二 进 制 日 志文 件 来 查看 用 户 执 行 了 哪些 操作 ,对 数据 库 文件 做 了 哪些 修改 等 。 
然后 根据 二 进 制 日 志文 件 的 记录 来 修复 数据 库 。 

需要 了 解 的 是 ,启动 日 志 功 能 会 降低 MySQL 数据 库 的 性 能 。 同 时 ,日 志 会 占用 大 量 的 
磁盘 空间 。 如 果 是 用 户 量 非常 大 ,操作 又 非常 频繁 的 数据 库 ,日 志文 件 需 要 的 存储 空间 甚至 
比 数 据 库 文件 需要 的 存储 空间 还 要 大 。 

3. 上 机 练习 题 (本 题 利用 teaching 数据 库 进 行 操 作 ) 

(1) 使 用 show variables 语句 查询 当前 日 志 设 置 。 


答 : 代码 和 运行 结果 如 下 : 


mysql» show variables like 'log &'; 





log bin ON 
log bin basename | C:\ProgramData\MySQL\MySQL Server 
5. 7NDataVPGIGIMIWMYPOFBS - bin 
log bin index | C: XProgranData MySQL AMySQL Server 
5. "Data V PGIGI MIWMYPOFBS ~ bin. index 
log bin trust function creators OFF 
log bin use vl row events OFF 
log builtin as identified by password | OFF 
log error | . NPGIG1MIWMYPOFBS. err 
log error verbosity 3 
log output FILE 
log queries not using indexes OFF 
log slave updates OFF 
log slow admin statements OFF 
log slow slave statements OFF 


log statements unsafe for binlog ON 
log syslog ON 
log syslog tag 
log throttle queries not using indexes | 0 
log timestamps UTC 

log warnings 2 











19 rows in set, 1 warning (0.00 sec) 


(2) 使 用 show binary logs 查看 二 进 制 日 志文 件 的 个 数 及 文件 名 。 
答 : 代码 和 运行 结果 如 下 : 


mysql» show binary logs; 


4---------------------- 4-------- 十 
| Log_name |File size | 
4---------------------- 4-------- * 
| PGIGLMIWMYPOFBS - bin. 000037 | 177| 
| PGIGIMIWMYPOFBS - bin. 000038 | 699 | 
| PGIGLMIWMYPOFBS - bin. 000039 | 9799 | 
| PGIGIMIWMYPOFBS - bin. 000040 | 4268 | 
| PGIGIMIWMYPOFBS - bin. 000041 | 9456 | 
| PGIGIMIWMYPOFBS - bin. 000042 | 2562 | 
4---------------------- 4-------- * 


6 rows in set (0.06 sec) 


(3) 使 用 purge master logs 删除 2017 Æ 8 H 30 日 前 创建 的 所 有 日 志文 件 。 
答 : 代码 和 运行 结果 如 下 : 


mysql» purge master logs before '20170830'; 
Query OK, 0 rows affected, 1 warning (0.11 sec) 


IE 





(MySQL 4E E E S TEXAS EX 


MySQL 4t 4E E E JH 5 7E A LEE 5 Edu 





# 语 句 执 行 之 后 ,2017 年 8 月 30 日 之 前 创建 的 日 志文 件 都 将 被 删除 ,但 2017 年 8 月 30 日 的 


# 日 志 会 被 保留 


OD 使 用 记事 本 查看 MySQL 错误 日 志 。 
答 : 代码 和 运行 结果 如 下 : 


# 通 过 show variables 语句 查询 错误 日 志 的 存储 路 径 和 文件 名 

show variables like 'log error'; 
# 可 以 看 到 错误 的 文件 是 log error, 位 于 MySQL 默认 的 数据 目录 下 ,使 用 记事 本 打开 该 文件 ,可 以 看 
* 到 MySQL 的 错误 日 志 


2017 - 06 - 30T09: 
2017 - 06 - 30T09: 
2017 - 06 - 30T09: 
2017 - 07 - 23113: 
2017 - 07 - 23113: 
2017 - 07 - 23113: 
2017 - 07 - 23113: 
2017 - 07 - 237113: 
2017 - 07 - 23713: 
2017 - 07 - 25123: 


53: 
53: 
53: 
42: 
42: 
42: 
42: 
42: 
42: 
49: 


27. 
28. 
32; 
31. 


31 


31 


921504Z 0 [Note] InnoDB: Number of pools: 1 

046304Z 0 [Note] InnoDB: Not using CPU crc32 instructions 
7723132 0 [Note] InnoDB: Waiting for purge to start 
071708Z 0 [Note] Shutting down plugin 'INNODB CMPMEM' 


.071708Z 0 [Note] Shutting down plugin 'INNODB CMP RESET' 
31. 
31. 


071708Z 0 [Note] Shutting down plugin 'INNODB CMP' 
071708Z 0 [Note] Shutting down plugin 'INNODB LOCKS' 


.071708Z 0 [Note] Shutting down plugin 'INNODB TRX' 
3i. 
09. 


071708Z 0 [Note] Shutting down plugin 'InnoDB' 
261507Z 0 [Note] End of list of non- natively partitioned tables 


2017 - 07 - 25T23:49: 09. 261507Z 0 [Note] C: \ Program FilesVMySQLV MySQL Server 5. 7NbinN 
mysqld.exe: ready for connections. 


Version: '5.7.17 - log' 


Socket: ''port: 3306 MySQL Community Server (GPL) 


以 上 是 错误 日 志文 件 的 一 小 部 分 ,这 里 面 记载 了 系统 的 一 些 错误 。 


14. 


14. 
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14.1 教学 要 求 


1.1 基本 要 求 


(1) 了 解 PHP 语言 的 特点 和 工作 原理 。 

(2) 掌握 搭建 PHP 十 MySQL 的 集成 开发 环境 的 过 程 。 

(3) 了 解 配置 集成 开发 环境 (IDE) 常 用 软件 NetBeans 的 安装 和 配置 过 程 。 
(4) 学 会 安装 和 配置 Apache 软件 。 

G) 掌握 PHP 语言 连接 MySQL 服务 器 的 操作 步骤 。 

(6) 掌握 使 用 PHP 管理 MySQL 数据 库 的 基本 操作 语句 。 

(7) 掌握 使 用 PHP 处 理 MySQL 结果 集 的 语句 。 

(8) 了 解 使 用 mysqli_free_result() 函 数 释 放 内 存 的 过 程 。 


1.2 重点 与 难点 


1. 本 章 重 点 

(1) 搭建 PHP 十 MySQL 的 集成 开发 环境 的 过 程 。 
(2) 配置 集成 开发 环境 (IDE) 常 用 软件 NetBeans 的 安装 和 配置 过 程 。 
(3) 安装 和 配置 Apache 软件 。 

(4) 使 用 PHP 管理 MySQL 数据 库 的 基本 操作 语句 。 
(5) 使 用 PHP 处 理 MySQL 结果 集 的 语句 。 

2. 本 章 难 点 

(OD PHP 语言 的 工作 原理 。 

(2) 搭建 PHP+MySQL 的 集成 开发 环境 的 过 程 。 
(3) 安装 和 配置 Apache 软件 。 

(4) PHP 语言 连接 MySQL 服务 器 的 操作 。 

(5) 使 用 PHP 管理 MySQL 数据 库 的 基本 操作 。 

(6) 使 用 PHP 处 理 MySQL 结果 集 的 语句 。 
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14.2 习题 参考 答案 


1. 思考 题 

COD 简 述 PHP 语言 的 基本 特点 。 

4. PHP 是 英文 超级 文本 预 处 理 语 言 Hypertext Preprocessor 的 缩写 。PHP 是 一 种 
HTML 内 内 式 的 语言 ,是 一 种 在 服务 器 端 执行 的 戏 入 HTML 文档 的 脚本 语言 ,语言 的 风格 
类 似 于 C 语言 ,被 广泛 运用 。 

(2) 简 述 利用 PHP 与 MySQL 数据 库 连 接 的 步骤 。 

答 :使 用 PHP 进行 MySQL 数据 库 编 程 的 基本 步骤 如 下 

(D 建立 与 MySQL 数据 库 服 务 器 的 连接 。 

@ 选择 要 对 其 进行 操作 的 数据 库 。 

@ 再 执行 相应 的 数据 库 操作 ,包括 对 数据 的 添加 、 删 除 、 修 改 和 查询 等 。 

@ 关闭 与 MySQL 数据 库 服务 器 的 连接 。 

(3) 设置 结果 集 数组 的 表述 方式 中 的 mysqli_assoc、mysqli_num 和 mysqli_both 分 别 
表示 什么 ? 

答 : 使 用 mysqli_fetch_array() 函 数 将 结果 集 返 回 到 数组 的 操作 过 程 中 ,使 用 mysqli_ 
query() 函 数 执行 select 语句 时 ,将 成 功 返 回 查 询 结果 集 ,返回 结果 集 后 ,使 用 mysqli_fetch_ 
array() 函 数 可 以 获取 查询 结果 集 信息 ,并 放 入 到 一 个 数组 中 ,这 些 数组 的 类 型 如 下 : 

。 mysqli_assoc: 表示 数组 采用 关联 索引 。 
* mysqli num: 表示 数组 采用 数字 索引 。 
。 mysqli_both: 同时 包含 关联 和 数字 索引 的 数组 。 

其 中 ,mysqli_both 是 默认 值 。 

(4) 简 述 mysali query O PR Zt f ff JH . 

^E . 使 用 mysqli_query() 函 数 可 以 执行 SQL 语句 。 在 PHP 中 ,通常 使 用 mysali query O 
函数 来 执行 对 数据 库 操作 的 SQL 语句 ,包括 对 数据 进行 查询 、 插 入、 更 新 和 删除 等 操作 。 
mysqli_query() 函数 一 次 只 能 执行 一 条 SQL 语句 。 如 果 SQL 语句 是 insert 语句 update i 
AJ delete 请 句 等 ,语句 执行 成 功 ,mysqli_query() 函 数 返 回 true, 否 则 返回 false。 并 且 可 以 
通过 mysqli_affected_rows() 函 数 获取 发 生变 化 的 记录 数 。 

2. 上 机 练习 题 (本 题 利用 teaching 数据 库 中 的 表 进 行 操作 ) 

(1) 利用 PHP 语言 查询 数据 表 course 中 的 数据 。 

答 : 代码 和 运行 结果 如 下 : 

<?php 

# 连接 mysql 数据 库 服 务 器 

$ connl = mysqli_connect("localhost", "root", "123456" ); 
$ select = nysqli select db( $ connl, "teaching"); // 连 接 服务 器 中 的 teaching 
if( $ select) 

{ 


header("Content - Type:text/html;charset = gb2312"); // 设 置 字符 集 
echo "数据 库 连 接 成 功 !”; // 判 断 是 否 连接 成 功 


) 
$ query = "select * from course"; 
$ result = mysqli query( $ conn, $ query) or die(" Zr ifj A Wr!" mysgli error()); 
echo mysqli affected rows( $ connl); 
> 


运行 结果 : 
数据 库 连 接 成 功 !13 


(2) 利用 mysqli query O PRZXIS] course 表 插 和 人 数据。 
答 : 主要 代码 如 下 : 


$ sqlinsert = "insert into course values('c05192', 'oracle', ' 必 修 ', 48,16,3)"; 
$ result = mysqli query( $ conn1, $ sqlinsert) or die("jfi A AW". mysgli error()); 


(3) 利用 mysqli query O PR SII course 表 数 据 。 
dk. 主要 代码 如 下 : 


$ sqldelete = "delete from course where courseno = 'c05108'"; 
mysqli query( $ conn1, $ sqldelete); 


CD 利用 mysqli query O PR CHE 9r course 表 数 据 。 
答 : 主要 代码 如 下 : 


$ sql update = "update course set cname = ' 机 械 零 件 ' where courseno- 'c06108'"; 
mysqli_query( $ conn, $ sqlupdate); 


(5) 查询 教师 号 为 t05001 的 教师 信息 ,并 利用 输出 命令 echo 和 print_r() 函 数 两 种 方 
Ew nm 
答 : PHP 代码 和 运行 结果 如 下 : 


«?php 
* 连接 MySQL 数据 库 服务 器 
$ connl = mysqli connect("localhost","root","123456"); 
$ select = nysqli select db( $ connl, "teaching"); // 连 接 服务 器 中 的 teaching 
if( $ select) 
{ 
header("Content- Type: text/html; charset = gb2312 ");  // 设 置 字符 集 
echo "ftf E ERD!" ; // 判 断 是 否 连接 成 功 
) 
$ sql = "select * from teacher where teacherno = 't05001';"; 
if ($result = mysqli query( $ conni, $ sq1)) 
t 
while ( $ row= mysqli_fetch_assoc( $ result) ) 
{ 
echo "<br /»"; 
echo "echo 格式 : "." <br />"; 


echo "教师 号 : ". $ row[ 'teacherno']; 
echo " 教师 姓名 : ". $ row[ 'tname']; 
echo " 专业 : ". $ row['major']; 
echo " 职称 : ". $ row['prof']; 
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echo " 部 门 : ". $ row['department']." <br />"; 
echo "print r() BUE X: "." <br />"; 
print r( $ row); 


) 
mysqli free result( $ result); // 释 放 内 存 


) 
// 关 闭 连接 对 象 


mysqli close( $ connl); 
?» 


m 
A 
E 
| 


运行 


数据 库 连 接 成 功 ! 


echo 格式 : 
教师 号 : t05001 教师 姓名 : 苏 超然 专业 : 软件 工程 ”职称 : 教授 部门: 计算 机 学 院 


print_r() 函 数 格式 : 
Array ([teacherno] = > t05001 [tname] => 苏 超然 [major] => 软件 工程 [prof] => 教授 


[department] => 计算 机 学 院 ) 
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数据 库 应 用 开发 实例 


1.1 基本 要 求 


CD THE MySQL 数据 库 在 实例 开发 过 程 中 的 背景 和 意义 。 
(2) 了 解 系统 开发 的 可 行 性 分 析 过 程 。 

(3) 掌握 如 何 确定 开发 项 目的 目标 的 过 程 。 

(4) 掌握 如 何 利 用 软件 工程 的 知识 对 系统 进行 需求 分 析 的 步骤 。 
(5) 了 解数 据 字 典 开发 的 意义 。 

(6) 掌握 如 何 设计 数据 库 的 概念 结构 和 逻辑 结构 。 

(7) 掌握 E-R 图 和 设计 数据 表 的 关系 。 

(8) 掌握 利用 JSP 技术 访问 MySQL 数据 的 基本 操作 。 

(9) 掌握 利用 MySQL 数据 库 设 计 在 线 考试 系统 的 过 程 。 


1.2 重点 与 难点 


1. 本 章 重 点 

(1) MySQL 数据 库 在 实例 开发 过 程 中 的 背景 和 意义 。 

(2) 如 何 确定 开发 项 目的 目标 的 过 程 。 

(3) 如 何 利 用 软件 工程 的 知识 对 系统 进行 需求 分 析 的 步骤 。 
(4) 如 何 设计 数据 库 的 概念 结构 和 人 逻辑 结构 。 

(5) E-R 图 和 设计 数据 表 的 关系 。 

(6) 利用 JSP 技术 访问 MySQL 数据 的 基本 操作 。 

2. 本 章 难 点 

(1) 如 何 确定 开发 项 目的 目标 的 过 程 。 

(2) 如 何 利用 软件 工程 的 知识 对 系统 进行 需求 分 析 的 步骤 。 
(3) 如 何 设计 数据 库 的 概念 结构 和 逻辑 结构 。 

(4) E-R 图 和 设计 数据 表 的 关系 。 

(5) 有 关 JSP 技术 的 基本 操作 。 
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15.2 习题 参考 答案 


1. 选择 题 
CD 在 关系 数据 库 设 计 中 .设计 关系 模式 属于 数据 库 设计 的 " 
A. 需求 分 析 阶 段 B. 概念 设计 阶段 C. 逻辑 设计 阶段 D. 物理 设计 阶段 




















(2) E-R 图 提供 了 表示 信息 世界 中 实体 、 属 性 和 的 方法 。 
A. 数据 B. 联系 C. X D. 模式 
(3) E-R 图 是 数据 库 设计 的 工具 之 一 , 它 一 般 适 用 于 建立 数据 库 的 * 
A. 逻辑 模型 B. 结构 模型 C. 物理 模型 D. 概念 模型 
(4) 将 E-R 图 转换 到 关系 模式 时 ,实体 与 联系 都 可 以 表示 成 s 
A. 属性 B. 关系 c. 键 D. 域 
(5) 如 果 关 系 模式 R 属于 1NF, 且 每 个 非 主 属性 都 完全 函数 依赖 于 R 的 主 码 , 则 R 属 
F , 
A. 2NF B. 3NF C. BCNF D. 4NF 
本 题 答案 : CBDBA 
2. 思考 题 


(1) 简 述 MySQL 数据 库 设计 优化 的 基本 过 程 。 

答 : 优化 数据 库 模型 需要 对 MySQL 适合 的 模型 进行 转换 。 转 换 的 主要 依据 是 
MySQL 数据 库 管理 系统 的 功能 及 限制 。 

因此 ,数据 库 逻 辑 设计 的 结果 不 是 唯一 的 。 得 到 初步 数据 模型 后 ,还 应 该 适当 地 修改 、 
调整 数据 模型 的 结构 ,以 进一步 提高 MySQL 数据 库 应 用 系统 的 性 能 ,这 就 是 数据 模型 的 优 
化 。 关 系数 据 模型 的 优化 通常 以 规范 化 理论 为 指导 ,优化 数据 模型 的 方法 主要 体现 在 确定 
数据 依赖 。 按 需求 分 析 阶 段 所 得 到 的 语义 并 不 是 规范 化 程度 越 高 的 关系 就 越 优 , 当 查 询 经 
常 涉及 两 个 或 多 个 关系 模式 的 属性 时 ,系统 必须 经 常 地 进行 连接 运算 。 对 于 一 个 具体 应 用 
来 说 ,到 底 规范 化 进行 到 什么 程度 ,需要 权衡 响应 时 间 和 潜在 问题 两 者 的 利 浆 才 能 决定 。 

(2) 简 述 对 于 系统 功能 进行 分 析 的 基本 要 求 。 

答 : 任何 一 个 软件 系统 的 设计 与 开发 都 需要 进行 详细 的 需求 分 析 , 其 目的 就 是 尽量 快 
速 、 准 确 、 全 面 地 获得 系统 的 真实 需求 ,规划 出 系统 的 整体 功能 ,为 系统 的 设计 与 实现 做 好 完 
备 而 坚实 的 基础 ,使 系统 的 开发 工作 得 以 顺利 进行 。 

性 能 需求 是 指 系统 必须 满足 的 定时 约束 或 容量 约束 ,通常 体现 在 终端 用 户 接 人 速率 、 响 
应 时 间 、 稳 定性 、 可 扩展 性 和 并 发 用 户 支 持 等 几 个 方面 。 具 体 说 来 包括 如 下 三 个 方面 。 

(D 可 靠 性 。 系 统 要 求 选用 可 靠 的 计算 机 及 网 络 设备 ,数据 库 服 务 器 等 在 条 件 允 许 的 条 
件 下 还 需 采用 磁盘 镜像 技术 。 数 据 库 及 操作 系统 软件 要 采用 成 熟 的 、 能 提供 有 效 技术 支持 
的 主流 产品 ,应 用 软件 的 设计 编制 应 遵循 规范 化 标准 ,整个 项 目的 开发 过 程 应 得 到 有 效 
监控 。 

@ 安全 性 。 系 统 的 安全 性 是 非常 重要 的 ,合理 的 安全 控制 可 以 使 应 用 系统 中 的 信息 资 


源 得 到 有 效 的 保护 , 故 系统 在 数据 库 层 和 应 用 层 都 做 了 安全 方面 的 设置 : 对 所 有 系统 用 户 
需要 有 完善 的 口令 加 密 功 能 ,以 保证 系统 及 数据 的 安全 性 。 应 用 软件 对 输入 的 数据 进行 合 
法 性 有 效 性 和 完整 性 检验 ,如 果 输 入 数据 存在 问题 ,系统 应 能 及 时 给 予 提示 。 

C 易 用 性 。 系 统 的 软 硬 件 设计 面向 非 专业 的 管理 人 员 ,管理 系统 具有 美观 友好 的 操作 
界面 ,使 用 简捷 、 易 懂 易 学 。 

(3) 说 明 关 系 模型 的 基本 术语 的 含义 。 

答 : 在 关系 数据 库 中 ,有 以 下 几 个 常见 的 关系 术语 。 

(D 关系。 关系 就 是 一 个 二 维 表格 ,每 个 关系 都 有 一 个 关系 名 ,在 MySQL 中 ,一 个 关系 
称 为 一 个 表 (Table) 。 

O 元 组 (记录 )。 在 一 个 具体 的 关系 中 , 表 中 的 一 行 称 为 一 个 元 组 (记录 ) 。 

C 属性 (字段 ) 。 表 中 的 一 列 即 为 一 个 属性 (字段 ), 给 每 一 个 属性 起 一 个 名 称 即 属 
性 名 。 

CD 域 。 属 性 的 取 值 范围 ,如 成 绩 的 范围 一 般 为 0 一 100 ,性别 的 域 是 ( 男 , 女 ) 等 。 

C 码 。 也 称 为 键 。 表 中 的 某 个 属性 组 , 它 可 以 唯一 确定 一 个 元 组 ,如 学 生 学 号 ,可 以 唯 
一 确定 一 个 具体 的 学 生 ,也 就 成 为 学 生 关系 的 码 。 

@ 分 量 。 元 组 中 的 一 个 具体 的 属性 值 , 称 为 分 量 。 

CD 关系 模式 。 对 关系 的 描述 称 为 关系 模式 ,一 个 关系 模式 对 应 一 个 关系 ,是 命名 的 属 
性 集合 ,一 般 表示 为 : 


关系 名 (属性 名 1, 属 性 名 2,.…, 属 性 名 n) 
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第 2 部 分 
MySQL 数 据 库 的 实验 指导 与 实验 安排 





学 习 导 读 : 

本 部 分 包括 本 课程 的 实验 指导 和 实验 内 容 两 方面 内 容 。 

实验 指导 部 分 包括 MySQL 的 实验 环境 的 进一步 介绍 ,还 
A MySQL 常用 的 两 个 可 视 化 软件 Navicat for MySQL 和 
phpMyAdmin 的 基本 操作 ,以 及 进行 本 课程 实验 的 基本 规范 和 
建议 。 

实验 内 容 共 包括 16 个 实验 ,实验 1 一 实验 14 的 运行 环境 
是 MySQL 5. 7. 17 软件 和 MySQL Workbench 可 视 化 软件 , 实 
验 15 的 运行 环境 还 需要 PHP 7.1 fe Apache 2. 4 软件 ,实验 16 
是 综合 性 实验 ,利用 phpMyAdmin 软件 ,以 “汽车 销售 管理 数据 
库 -arsales_info” 为 例 , 将 MySQL 的 重点 内 容 ( 如 数据 库 、 表 及 
数据 完整 性 .SQL 查询 视图、 存储 程序 、 导 入 导出 、 账 户 与 权限 
管理 二进制 文件 管理 等 ) 操 作 了 一 遍 , 每 一 个 实验 的 内 容 安 排 
都 与 主教 材 的 相关 章节 对 应 。 

实验 过 程 中 ,建议 除了 利用 本 书 的 代码 外 ,还 可 以 不 断 修改 
各 种 数据 和 参数 进行 实验 操作 。 在 实验 过 程 中 ,对 于 可 视 化 软 
件 的 操作 ,可 以 多 尝试 操作 一 下 教材 中 因 篇 幅 关 系 未 介绍 的 操 
作 。 另 外 ,读者 不 需要 熟悉 每 一 种 可 视 化 软件 ,熟悉 其 中 的 一 种 
PT, 
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MySQL 数据 库 的 实验 操作 相对 于 Oracle 和 SQL Server, 需 要 更 加 熟悉 实验 环境 。 
Oracle 功能 强大 ,数据 处 理 能 力 强 , 有 着 功能 完善 的 企业 管理 器 ,对 于 初学 者 有 很 好 的 帮 
Hj. SQL Server 采用 集成 化 界面 设计 ,将 查询 分 析 器 .企业 管理 器 和 对 象 资源 管理 器 等 工 
具 集 成 在 一 起 ,尤其 是 其 可 视 化 操作 性 能 强大 ,几乎 能 够 实现 所 有 基本 操作 。 

MySQL 数据 库 的 基本 操作 相对 简单 一 些 , 实 验 中 常用 到 的 工具 主要 包括 安装 完成 后 
自 带 的 命令 工具 。 另 外 ,熟悉 MySQL 实验 环境 的 配置 和 数据 库 操作 过 程 中 常见 的 错误 代 
码 也 是 实验 过 程 中 不 可 分 割 的 环节 。 

本 章 将 从 实验 操作 的 角度 ,详细 介绍 MySQL 数据 库 中 的 自 带 命令 工具 的 操作 、MySQL 
命令 的 执行 ,常用 的 MySQL 数据 库 的 手工 配置 和 实验 过 程 中 的 常见 错误 代码 标识 等 内 容 。 


16.1 MySQL 的 自 带 命令 


安装 MySQL 数据 库 成 功 后 ,会 在 安装 目录 中 找到 bin 文件 夹 ,该 文件 夹 包 含 了 可 执行 
文件 ,如 mysql. exe、mysqld. exe 和 mysqladmin. exe 等 。 下 面 将 介绍 一 些 常见 的 命令 ,并 且 
使 用 它们 进行 简单 的 操作 。 
16.1.1 查看 自 带 的 命令 工具 


查看 MySQL 数据 库 自 带 的 命令 工具 很 简单 ,找到 MySQL 数据 库 的 文件 安装 路 径 下 
的 bin 文件 夹 并 打开 ,如 图 16-1 所 示 。 
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图 16-1 bin 文件 夹 下 的 命令 
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从 图 16-1 中 可 以 看 出 ,MySQL 数据 库 中 自 带 了 多 个 命令 工具 ,通过 执行 这 些 命令 可 以 
实现 不 同 的 操作 ,大 多 数 的 操作 都 是 通过 mysql 命令 来 实现 的 。 另 外 ,mysqladmin 命令 主 
要 用 来 显示 服务 器 状态 ,mysqlimport 使 用 load data infile 将 文本 文件 导入 相关 表 的 客户 程 
Æ. K 16-1 对 图 16-1 中 的 常用 工具 进行 了 简单 说 明 。 


命令 工具 


表 16-1 MySQL 中 的 常用 命令 工具 
dog 





myisampack 


压缩 MyISAM 表 以 产生 更 小 的 只 读 表 的 一 个 工具 

















mysql 交互 式 输入 SQL 语句 或 从 文件 以 批 处 理 模式 执行 它们 的 命令 行 工具 
meann | 执行 管理 操作 的 客户 程序 ,例如 管理 数据 库 、 重 载 授权 表 、 将 表 保存 到 硬盘 上 ,以 及 重新 
”| 打开 日 志文 件 。mysqladmin 还 可 以 用 来 检索 版 本 、 进 程 ,以 及 服务 器 的 状态 信息 

从 三 进 制 日 志 读 取 语句 的 工具 。 在 二 进 制 日 志文 件 中 包含 执行 过 的 语句 的 日 志 可 用 来 

mysqlbinlog 
帮助 从 崩溃 中 恢复 

mysqlcheck | 检查 、 修 复 \ 分 析 以 及 优化 表 的 表 维 护 客 户 程序 
mysqldump | 将 MYSQL 数据 库 转 储 到 一 个 文件 (例如 SQL 语句 或 Tab 分隔 符 文本 文件 ) 的 客户 


程序 





mysqlimport 


使 用 load data infile 将 文本 文件 导入 相关 表 的 客户 程序 





mysqlshow 


显示 数据 库 、 表 、 列 以 及 索引 相关 信息 的 客户 程序 





perror 





显示 系统 或 MySQL 错误 代码 含义 的 工具 


16.1.2 DOS 窗口 执行 命令 


K 16-1 所 列 出 的 命令 通常 都 是 在 DOS 窗口 中 执行 操作 的 ,运行 这 些 命令 时 有 以 下 两 
种 方式 : 直接 进入 安装 路 径 的 目录 的 bin 目录 下 ,然后 运行 命令 查看 ; 将 路 径 添加 到 Path 
环境 变量 中 ,然后 直接 在 DOS 窗口 中 执行 命令 。 

1. 直接 进入 安装 路 径 的 bin 目录 

这 些 命令 实现 的 过 程 是 : 执行 “开始 ”一 “运行 ”命令 ,弹出 “运行 "对 话 框 ,输入 cmd 后 按 
Enter 键 打开 DOS 窗口 ,效果 如 下 : 


Microsoft Windows [版 本 6.1.7601] 
版 权 所 有 (c) 2009 Microsoft Corporation, f ELE BUR. 
C:\Users\Administrator > 


打开 DOS 窗口 后 首先 执行 CD 命令 进入 MySQL 数据 库 bin 文件 夹 ,结果 如 下 : 


C:NUsersMAdninistrator > CD C:\Program Files\MySQL\MySQL Server 5.7\bin 

C:\Program Files\MySQL\MySQL Server 5.7\bin> 

进入 MySQL 安装 路 径 下 的 bin 目录 后 ,直接 执行 mysql 命令 ,并 以 root 的 身份 登录 
MySQL 管理 系统 。 输 出 结果 如 下 : 


C:\Program Files\MySQL\MySQL Server 5.7\bin>mysql -u root -p 
Enter password: ****** 

Welcome to the MySQL monitor. Commands end with ; or Vg. 

Your MySQL connection id is 5 

Server version: 5.7.17 - log MySQL Community Server (GPL) 


Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. 
Oracle is a registered trademark of Oracle Corporation and/or its 
affiliates. Other names may be trademarks of their respective owners. 

Type 'help;'or '\h' for help. Type '\c' to clear the current input statement. 
mysql > 


如 果 用 户 想 要 退出 当前 命令 并 执行 其 他 命令 (如 mysqladmin) ,执行 exit 命令 退出 当前 
命令 ,重新 回 到 bin 文件 夹 。 输 出 结果 如 下 : 


mysql> quit 
Bye 
C:\Program Files\MySQL\MySQL Server 5. 7Vbin» 


2. 将 路 径 添加 到 Path 环境 变量 中 

通过 第 1 种 方式 虽然 可 以 执行 命令 语句 ,但 是 它 相 当 烦 琐 , 如 果 开 发 者 关闭 当前 DOS 
窗口 打开 一 个 新 窗口 时 ,还 需要 重新 进入 安装 目录 。 可 以 将 安装 路 径 添加 到 Path 环境 变量 
中 ,然后 在 DOS 窗口 中 直接 执行 命令 运行 。 具 体 实现 的 过 程 可 以 参看 教材 第 1 章 的 内 容 。 

系统 变量 设置 完成 后 ,重新 启动 计算 机 后 打开 DOS 窗口 。 直 接 执行 mysqlshow 命令 
进行 操作 ,输出 结果 如 下 : 


C:\Users\Administrator > mysqlshow — u root -p 
Enter password: *****x* 


information schema 
booksngt 

db examsystem 
mysql 

mysqltest 
performance schema 
sakila 

student 

sys 

teaching 








world 


16.1.3 mysqladmin 命令 


mysqladmin 命令 与 mysql 命令 一 样 ,经 常会 使 用 到 , 它 主 要 用 来 对 数据 库 做 一 些 简单 
操作 ,以 及 显示 服务 器 状态 等 。mysqladmin 命令 的 基本 语法 格式 如 下 : 

mysqladmin [option] command [command option] command ... 

直接 在 DOS 窗口 中 执行 mysqladmin 语句 或 者 输入 “mysqladmin -?” 可 以 打印 出 它 的 
帮助 信息 。 

1. mysqladmin 命令 的 相关 选项 

帮助 信息 包括 3 部 分 ,第 1 部 分 为 mysqladmin 命令 的 常用 选项 , 表 16-2 对 常用 的 选项 
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进行 了 说 明 。 
表 16-2 mysqladmin 命令 的 常用 选项 
选项 名 称 说 明 
-c, --count— & 自动 运行 次 数 ,必须 和 -i 一 起 使 用 
-f, --force 禁用 错误 ,drop 数据 库 时 不 提示 ,执行 多 条 命令 时 出 错 继续 执行 
-C, --compress 在 服务 器 和 客户 端 之 间 使 用 压缩 
--character-sets-dir— name 设置 字符 集 目 录 
--default-character-set— name 设置 字符 集 默 认 目录 
-?，--help 显示 帮助 信息 
-h, --host— name 主机 名 
-p, --password[ = name] 服务 器 连接 密码 
-P, --port— # 端口 号 
--protocol— name 设置 连接 使 用 的 协议 
-s, --silent 如 果 连 接 服务 器 失败 则 退出 
-u, --user= name 用 户 名 
-V, --version 显示 mysqladmin 的 版 本 
-E, --vertical 垂直 显示 输出 
-w, --wait[ — & ] 如 果 连 接 断 开 , 则 等 待 并 重 试 
--connect_timeout 一 & 连接 超时 
--shutdown timeout— # 超时 关闭 


【 例 16-1] 直接 打开 DOS 窗口 ,并 且 输 入 "mysqladmin -V” 查 看 当前 mysqladmin 的 


版 本 。 


代码 和 运行 结果 如 下 : 


C:\Users\Administrator > mysqladmin - V 


mysqladmin Ver 8.42 Distrib 5.7.17, for Win32 on AMD64 


2. mysqladmin 的 可 执行 命令 
mysqladmin 帮助 信息 的 第 2 部 分 表示 mysqladmin 的 相关 变量 。 第 3 部 分 表示 
mysqladmin 可 以 执行 的 相关 服务 器 命令 ,目前 mysqladmin 支持 的 命令 有 创建 新 的 数据 库 、 
删除 一 个 数据 库 , 以 及 清除 所 有 缓存 的 主机 和 所 有 日 志 等 , 表 16-3 针对 这 些 命令 进行 了 详 
细 说 明 。 
表 16-3 mysqladmin 可 以 执行 的 命令 
命令 名 称 说 明 
create databasename 创建 一 个 新 数据 库 
debug 用 于 通知 服务 器 将 调试 信息 写 人 日 志 
删除 一 个 数据 库 及 其 所 有 表 
显示 服务 器 的 一 个 扩展 状态 信息 
清除 所 有 缓存 的 主机 
清除 所 有 日 志 











drop databasename 





extended-status 





flush-hosts 








flush-logs 





S 





















































命令 名 称 说 明 
flush-status 清除 状态 变量 
flush-tables 清除 所 有 表 
flush-threads 清除 线程 缓存 
flush-privileges 再 次 装载 授权 表 ( 同 reload) 
kill id,id,... 杀 死 mysql 线程 
password[ new-password] 将 旧 口 令 改 为 新 口令 
old-password[ new-password ] 修改 口令 
ping 检查 mysqld 是 否 在 线 
processlist 显示 服务 器 中 的 活跃 线程 列表 
reload 重 载 授权 表 
refresh 刷新 所 有 表 并 关闭 和 打开 日 志文 件 
shutdown 关 掉 服务 器 
status 显示 服务 器 的 简短 状态 消息 
start-slave 启动 slave 
stop-slave 关闭 slave 
variables 打印 出 可 用 变量 
version 得 到 服务 器 的 版 本 信息 





[5)16-2] 直接 在 mysqladmin 命令 后 跟 ping 命令 检查 mysqld EBER. 


代码 和 运行 结果 如 下 : 


C:\Users\Administrator > mysqladmin -u root - p ping 


Enter password: **** 
mysqld is alive 


[B 16-3] 在 DOS 窗口 中 执行 mysqladmin 命令 时 ,也 可 以 通过 执行 version 命令 来 


查看 详细 信息 。 
代码 和 运行 结果 如 下 : 


C:\Users\Administrator > mysqladmin — u root - p version 


Enter password: ****** 


mysqladmin Ver 8.42 Distrib 5.7.17, for Win32 on AMD64 

Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. 
Oracle is a registered trademark of Oracle Corporation and/or its 
affiliates. Other names may be trademarks of their respective owners. 


Server version 5.7.17 - log 
Protocol version 10 

Connection localhost via TCP/IP 
TCP port 3306 

Uptime: 8 hours 21 min 13 sec 


Threads: 1 Questions: 14 Slow queries: 0 Opens: 108 Flush tables: 1 Open tables: 101 


Queries per second avg: 0.000 
C: \Users\Administrator > 
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16. 


【 例 16-4] 通过 执行 mysqladmin 命令 语句 查看 MySQL 的 状态 值 。 
代码 和 运行 结果 如 下 : 


C:\Users\Administrator > mysqladmin proc stat — u root - p 
Enter password: **x*x** 


4---4----4-------- 4---4------ 4----- ges eee * 
| Id | User| Host | db | Connand| Tine | State | Info | 
证 deep go--—-s € go + 
| 9 |root |localhost:62022 | | Query |0| starting |show processlist | 
E E taja poems gocce p + 


Uptime: 30623 Threads: 1 Questions: 17 Slow queries: 0 Opens: 108 Flush tables: 1 Open 
tables: 101 Queries per second avg: 0.000 

执行 命令 完毕 后 都 会 输出 状态 信息 。 下 面具 体 对 输出 的 各 项 信息 进行 说 明 : 
* Uptime: 表示 MySQL 服务 器 已 经 运行 的 秒 数 。 

。 Threads: 活动 线程 (客户 ) 的 数量 。 

。 Questions: 从 mysqld 启动 以 来 客户 问题 (查询 ) 的 数量 。 

Slow Query: 执行 时 间 超 过 long. query. time 秒 的 查询 数量 。 

Opens: 服务 器 已 经 打开 数据 库 表 的 数量 。 

* Flush tables; 服务 器 已 经 执行 的 flush refresh 和 reload 命令 的 数量 。 

* Open tables; 目前 打开 的 表 的 数量 。 

。 Queries per second avg: 执行 平均 用 时 秒 数 。 


1.4 mysqlshow 命令 
使 用 mysqlshow 命令 可 以 很 快 地 查找 存在 哪些 数据 库 \ 数 据 库 中 的 表 , 以 及 表 中 的 列 


或 者 索引 。 基 本 语法 如 下 : 


mysqlshow[ options] [db name [tal name [col name]]] 


在 上 述 所 示 的 语法 中 ,如 果 没 有 指定 数据 库 , 则 显示 所 有 匹配 的 数据 库 ; 如 果 没 有 指定 


数据 库 表 , 则 显示 数据 库 中 所 有 匹配 的 表 ; 如 果 没 有 给 出 列 , 则 显示 表 中 所 有 匹配 的 列 和 列 
类 型 。 


直接 执行 mysqlshow 或 “mysqlshow -?” 命 令 可 以 查看 该 命令 的 帮助 信息 ,输出 的 信息 


包括 两 部 分 : 第 1 部 分 显示 mysqlshow 命令 的 相关 选项 ,常用 选项 的 说 明 如 表 16-4 所 示 。 


表 16-4 mysqlshow 命令 的 相关 选项 























选项 名 称 说 明 

---help,-? 显示 一 个 帮助 消息 并 退出 

-C, --compress 压缩 所 有 的 客户 和 服务 器 之 间 发 送 的 信息 (如 果 它 们 都 支持 压缩 ) 

-h, --host=name 在 显示 的 主机 上 连接 MySQL 服务 器 

-k, --keys 显示 表 索 引 

-i, --status 显示 关于 每 个 表 的 额外 信息 
连接 服务 器 时 使 用 的 密码 。 如 果 使 用 短 选项 形式 (-p) ,不 能 在 选项 和 密码 

-p. --password[ —name] | 之 间 存 在 空格 。 如 果 在 命令 行 中 忽略 了 --password B-p 选项 后 面 的 密码 
值 ,将 提示 输入 一 个 密码 





续 表 














选项 名 称 说 明 
-u, --user= name 连接 服务 器 时 使 用 的 MySQL 用 户 名 
元 长 模式 ,打印 出 程序 操作 的 详细 信息 。 此 选项 可 以 多 次 使 用 以 便 增加 信 
-v, --verbose 
息 总 量 
-V, --version 显示 版 本 信息 并 退出 


例如 ,直接 在 DOS 窗口 中 执行 “mysqlshow mysql -V” 命 令 , 输 出 结果 如 下 : 


C:\Documents and Settings\Administrator > mysqlshow mysql —V 
mysqlshow Ver 9.10 Distrib 5.6.13, for Win32 (x86) 


【 例 16-5] 演示 mysqlshow 命令 的 简单 使 用 。 
(1) 在 DOS 窗口 中 执行 mysqlshow 命令 ,执行 完毕 后 会 显示 所 有 的 数据 库 和 表 。 前 面 


利用 该 语句 查看 过 数据 库 ,也 可 以 查看 指定 数据 库 中 的 所 有 表 和 视图 。 


代码 和 运行 结果 如 下 : 


C:\Users\Administrator > mysqlshow teaching - u root - p 
Enter password: x 
Database: teaching 


bef after 
course 
course avg 
de teacher 
mytest 
Score 

se course 
stu score 
stu view2 
student 
teach course 
teach viewl 
teacher 

v avgstu 

v dept 

v sex 








v teacher 


(2) 在 数据 库 之 后 指定 选项 -v, 会 输出 程序 操作 的 详细 信息 。 更 改 前 面 的 命令 ,为 上 述 


命令 指定 -v 选项 。 


代码 和 运行 结果 如 下 : 


C:\Users\Administrator > mysqlshow teaching -v -uroot -p 
Enter password: ****x** 
Database: teaching 
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bef after 
Course 
Course avg 
de teacher 
mytest 
Score 

se course 
stu score 
stu view2 
student 
teach course 
teach viewl 
teacher 

v avgstu 

v dept 

v sex 
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v teacher 
4---------- 4------- * 


17rows in set. 


(3) 利用 mysqlshow 命令 的 相关 语句 查看 数据 库 表 se_course, 并 使 用 选项 -v 指定 打印 
出 程序 操作 的 详细 信息 。 

代码 和 运行 结果 如 下 : 

C:\Users\Administrator > mysqlshow teaching se course -v -u root - p 


Enter password: *****x* 
Database: teaching Wildcard: se course 


4-------- 4£-------- * 
| Tables | Columns | 
4---———-—— += 一 一 ~ + 
| se course | 6 | 
4-------- 4-------- * 


16.1.5  mysglbinlog 命令 


mysqlbinlog 命令 是 用 于 处 理 二 进 制 日 志文 件 的 实用 工具 ,服务 器 生成 的 二 进 制 日 
志文 件 写成 二 进 制 格式 ,如果 要 检查 这 些 文本 格式 的 文件 ,可 以 使 用 mysqlbinlog 命令 
工具 。 

mysqlbinlog 命令 语法 如 下 : 


mysqlbinlog [options] log- files... 
开发 者 可 以 直接 在 DOS 窗口 中 执行 mysqlbinlog 或 “mysqlbinlog -?” 命 令 查看 帮助 信 


息 。 该 命令 显示 的 帮助 信息 包括 两 部 分 : 第 1 部 分 显示 mysqlbinlog 命令 的 相关 选项 ,常用 
选项 如 表 16-5 所 示 ; 第 2 部 分 显示 了 mysqlbinlog 命令 的 相关 变量 。 


表 16-5 mysqladmin 执行 的 相关 选项 


























选项 名 称 说 明 

-?，--help 显示 帮助 信息 并 退出 

-d, --database= name 只 列 出 该 数据 库 的 条 目 ( 只 用 于 本 地 ) 
使 用 该 选项 ,如 果 mysqlbinlog 读 它 不 能 识别 的 二 进 制 日 志 事件 , 它 会 

-f, --force -read 打印 警告 ,忽略 该 事件 并 继续 。 没 有 该 选项 ,如 果 mysqlbinlog 读 到 此 
类 事件 则 停止 

-H, --hexdump 在 注释 中 显示 日 志 的 十 六 进 制 转 储 

-h, --host=name 获取 给 定 主机 上 的 MySQL 服务 器 的 二 进 制 日 志 

-1, --local-load= name 为 指定 目录 中 的 load data infile 预 处 理 本 地 临时 文件 

TP. --port= # 用 于 连接 远程 服务 器 的 TCP/IP 端口 号 

--protocol— name 使 用 的 连接 协议 





从 MySQL 服务 器 读 二 进 制 日 志 。 如 果 未 给 出 该 选项 ,任何 连接 参数 
-R, --read-from-remote -server | 选项 将 被 忽略 。 这 些 选 项 是 - -host、- -password、- -port、- -protocol、 


--socket 和 --user 








-S, --socket= name 用 于 连接 的 套 接 字 文 件 
从 二 进 制 日 志 中 第 1 个 日 期 时 间 等 于 或 晚 于 datetime 参量 的 事件 开始 
--start-datetime— name 读 取 。datetime 值 相 对 于 运行 mysqlbinlog 的 机 器 上 的 本 地 时 区 。 该 


值 格式 应 符合 DATETIME 或 TIMESTAMP 数据 类 型 
从 二 进 制 日 志 中 第 1 个 日 期 时 间 等 于 或 晚 于 datetime 参量 的 事件 起 停 
止 读 。 关 于 datetime 值 的 描述 参见 --start-datetime 选项 





--stop-datetime— name 





通常 情况 下 ,可 以 使 用 mysqlbinlog 命令 直接 读 取 二 进 制 日 志文 件 ,并 将 文件 用 于 本 地 
MySQL 服务 器 ,也 可 以 使 用 --read-from-remote-server 选项 从 远程 服务 器 读 取 二 进 制 日 志 
文件 。 当 读 取 远程 二 进 制 日 志 时 ,可 以 通过 连接 参数 选项 来 指示 如 何 连 接 服 务 器 ,但 是 它 
们 经 常 被 忽略 ,除非 还 指定 了 --read-from-remote-server 选项 。 还 可 以 使 用 mysqlbinlog 来 
读 取 在 复制 过 程 中 从 服务 器 所 写 的 中 继 日 志文 件 , 中 继 日 志 格 式 与 二 进 制 日 志文 件 
相同 。 

【 例 16-6】 利用 mysqlbinlog 命令 输出 PGIGIMIWMYPOFBS-bin. 000005 文件 中 包 
含 的 所 有 语句 以 及 其 他 信息 。 如 果 指 定 的 文件 不 存在 , 则 会 输入 提示 信息 ,提示 该 文件 并 不 
存在 。 

代码 和 运行 结果 如 下 : 

C:\Users\Administrator > mysqlbinlog PGIG1MIWMYPOFBS - bin. 000005 

/ *150530 SET @ @SESSION. PSEUDO_SLAVE_MODE = 1 * /; 

/ * 150003 SET @OLD_COMPLETION_TYPE = @ @COMPLETION_TYPE, COMPLETION_TYPE = 0 * /; 

DELIMITER / * ! * /; 

mysqlbinlog: File 'PGIGIMIWMYPOFBS - bin. 000045 ' not found (Errcode: 2 - No such file or 

directory) 

SET (2(QSESSION.GTID NEXT = 'AUTOMATIC'/ * added by mysqlbinlog */ / * ! */; 

DELIMITER ; 

* End of log file 

/ * 150003 SET COMPLETION TYPE- (QOLD COMPLETION TYPE * /; 

/ * 150530 SET (2 (QSESSION.PSEUDO SLAVE MODE- 0 * /; 


Y Yeu 





MySQL 4t 46 Æ 85 3: 4e d 9 RIRH 


MySQL 4t 4E E E JH 5 7E A LEER 5 Edu 





16.1.6  perror 命令 


perror 命令 用 于 解释 错误 命令 ,对 于 大 多 数 系统 错误 ,除了 内 部 文本 信息 之 外 , MySQL 
还 会 按 下 面 的 风格 显示 系统 错误 代码 。 


message ... (Errcode: # ) 
message ... (errorno: # ) 


通过 检查 系统 文档 或 使 用 perror 工具 ,可 以 检查 错误 代码 的 意义 。perror 为 系统 错误 
代码 或 存储 引擎 ( 表 处 理 ) 错 误 代 码 打 印 其 描述 信息 。 
perror 命令 的 基本 语法 如 下 : 


perror [options] errorcode 


LBI 16-7] 执行 perror 命令 显示 的 错误 信息 。 
代码 和 运行 结果 如 下 : 


C:\Users\Administrator > perror 9 19 

OS error code 9: Bad file descriptor 
Win32 error code 9: 存储 控制 块 地 址 无 效 。 
OS error code 19: No such device 


Win32 error code 19: 介质 受 写 人 保护 。 
执行 perror 命令 查看 帮助 信息 ,输出 的 帮助 信息 如 下 : 


C:\Users\Administrator > perror 

perror Ver 2.11, for Win32 (AMD64) 

Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. 
Oracle is a registered trademark of Oracle Corporation and/or its 

affiliates. Other names may be trademarks of their respectiveowners. 

Print a description for a system error code or a MySQL error code. 

If you want to get the error for a negative error code, you should use 

—- before the first error code to tell perror that there was no more options. 
Usage: perror [OPTIONS] [ERRORCODE [ ERRORCODE...]] 


-?, -- help Displays this help and exits. 

-I, -- info Synonym for -- help. 

=s, -- silent Only print the error message. 

—v, —-- verbose Print error code and message (default). 
(Defaults to on; use —- skip- verbose to disable.) 

-V, -- version Displays version information and exits. 


Variables ( —— variable - name = value) 
and boolean options (FALSE|TRUE) Value (after reading options) 


由 此 帮助 信息 可 以 看 出 ,perror 命令 与 前 面 的 其 他 命令 相 比 .比较 简单 。 
16.2 MySQL 的 常用 命令 


MySQL 是 一 个 简单 的 SQL 工具 ,支持 交互 式 和 非 交 互 式 使 用 。 交 互 使 用 时 查询 结果 
采用 ASCII 表格 式 。 当 采用 非 交 互 式 模式 时 ,例如 用 作 过 滤器 ,其 结果 为 Tab 分 隔 符 格式 。 


16.2.1 


mysql 命令 的 语法 格式 


mysql 命令 的 基本 语法 如 下 : 


mysql [options] [database] 


在 DOS 窗口 中 可 以 直接 执行 mysql “mysql -?” 命 令 语句 查看 帮助 信息 , 表 16-6 对 帮 
助 信息 中 常用 的 一 些 选项 进行 了 介绍 。 


表 16-6 mysql 命 令 执 行 的 相关 选项 








选项 名 称 LX 
-?, --help 显示 帮助 信息 并 退出 
-— 打印 结果 ,使 用 Tab 作为 列 间 隔 符 ,每 个 行 占用 新 的 一 行 。 使 用 该 选 
-B, --batc 


项 , 则 mysql 不 使 用 历史 文件 














--character-sets-dir— name 字符 集 的 安装 目录 

-D, --database— name 要 使 用 的 数据 库 ,主要 在 选项 文件 中 使 用 
-T, --debug-info 当 程 序 退 出 时 输出 部 分 调试 信息 
--default-character-set—name | 使 用 name 作为 默认 字符 集 





-E, --vertical 


垂直 输出 查询 输出 的 行 。 如 果 没 有 该 选项 ,可 以 使 用 \G 结尾 指定 单个 
语句 的 垂直 输出 





-f, --force 


即使 出 现 一 个 SQL 错误 仍 继续 





-h, --host= name 


连接 指定 主机 上 的 MySQL 服务 器 


























-H, --html 产生 HTML 输出 

-N, --skip-column-names 在 结果 中 不 写 列 名 

-s, --silent 沉默 模式 ,产生 少 的 输出 。 可 以 多 次 使 用 该 选项 以 产生 更 少 的 输出 
-X, --xml 产生 XML 输出 

-n, --unbuffered 每 次 查询 后 刷新 缓存 区 

-u, --user— name 连接 服务 器 时 MySQL 使 用 的 用 户 名 

-v, --verbose 元 长 模式 。 产 生 更 多 的 输出 ,可 以 多 次 使 用 该 选项 以 产生 更 多 的 输出 
-V, --version 显示 版 本 信息 并 退出 





-ws --wait 


如 果 不 能 建立 连接 ,等 待 并 重 试 而 不 是 放弃 





--show-warnings 


如 果 每 个 语句 后 有 警告 则 显示 ,此 选项 适用 于 交互 式 和 批 处 理 模式 














--net-buffer-length— # TCP/IP 和 套 接 字 通 信 缓 冲 区 大 小 
--max-allowed-packet— # 从 服务 器 发 送 或 接收 的 最 大 包 长 度 
--connect-timeout— # 连接 超时 前 的 秒 数 


例如 ,直接 在 DOS 窗口 中 执行 “mysql -V” 命 令 查看 版 本 信息 ,输出 结果 如 下 : 


C:\Users\Administrator > mysql 


-V 


mysql Ver 14.14 Distrib 5.7.17, for Win32 (MAD64) 


16.2.2 MySQL 的 命令 


MySQL 的 命令 将 发 出 的 SQL 语句 发 送 到 待 执行 的 服务 器 ,还 有 一 系列 命令 MySQL 
可 以 自己 解释 。 如 果 要 查看 这 些 命令 ,在 mysql > 提示 符 下 输入 help 或 \h 语句 ,输出 结果 


如 下 : 
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mysql» Mh 

For information about MySQL products and services, visit: 
http://www. mysql. com/ 

For developer information, including the MySQL Reference Manual, visit: 
http: //dev. mysql. con/ 

To buy MySQL Enterprise support, training, or other products, visit: 
https: //shop. mysql. con/ 

List of all MySQL commands: 

Note that all text commands must be first on line and end with ';" 

$ (X?) Synonym for :help'. 

clear (\c) Clear the current input statement. 

connect (\r) Reconnect to the server. Optional arguments are db and host. 

delimiter (Md) Set statement delimiter. 


ego (NG) Send command to mysql server, display result vertically. 
exit (Aq) Exit mysql. Same as quit. 

go (Ng) Send command to mysql server. 

help (Ah) Display this help. 

notee (Nt) Don't write into outfile. 

print (Np) Print current command. 

prompt (M8) Change your mysql prompt. 

quit (Nq) Quit mysql. 

rehash (\ #) Rebuild completion hash. 

source (V. ) Execute an SQL script file. Takes a file name as an argument. 
status (As) Get status information from the server. 

tee (NT) Set outfile [to outfile]. Append everything into given outfile. 
use (Nu) Use another database. Takes database name as argument. 


charset (\C) Switch to another charset. Might be needed for processing binlogwith multi - byte 
charsets. 

warnings (WW) Show warnings after every statement. 

nowarning (Nw) Don't show warnings after every statement. 

resetconnection(WMx) Clean session context. 

For server side help, type 'help contents' 


MySQL 的 每 个 命令 都 有 长 形式 和 短 形 式 ,长 形式 对 大 小 写 不 敏感 ; 而 短 形式 则 需要 区 
长 形式 后 面 可 以 加 一 个 分 号 结束 符 ,但 是 短 形式 不 可 以 。 

【 例 16-8] status 命令 提供 连接 和 使 用 的 服务 器 相关 的 部 分 信息 。 
代码 和 运行 结果 如 下 : 


mysql» status 


mysql Ver 14.14 Distrib 5.7.17, for Win32 (AMD64) 


Connection id: 23 

Current database: 

Current user: root(2 localhost 

SSL: Not in use 

Using delimiter: 3 

Server version: 5.7.17 -— log MySQL Community Server (GPL) 
Protocol version: 10 

Connection: localhost via TCP/IP 


Server characterset: utf8 


Db characterset: utf8 

Client characterset: gbk 

Conn. characterset: gbk 

TCP port: 3306 

Uptime: 11 hours 39 min 24 sec 

Threads: 1 Questions: 90 Slow queries: 0 Opens: 125 Flush tables: 1 Open tables: 118 
Queries per second avg: 0.002 


若 执行 quit 或 exit 语句 则 退出 MySQL 执行 其 他 命令 的 状态 ,返回 DOS 界面 。 

有 些 情 况 下 , 当 被 查询 数据 库 表 中 的 数据 过 多 时 ,水 平 显示 这 些 数据 会 显得 杂乱 无 章 ， 
这 时 使 用 垂直 显示 更 加 容易 读 取 。 使 用 \G 而 不 用 分 号 结束 查询 可 以 垂直 显示 查询 。 

【 例 16-9】 查询 teaching 数据 库 下 se course 表 中 所 有 列 的 值 , 并 将 结果 以 垂直 方式 
输出 。 

代码 和 和 运行 结果 如 下 : 


mysql» SELECT * FROM se course VG 
OOKOCOOGOROOGOXOIOOOCX l, FOW XOOOCGOOOGOOOOOGOOOGOE 
SC no: 1 
studentno: 19120000111 
courseno: col236 
teacherno: t01237 
Score: NULL 
SC time: 2017 - 05 — 01 18:40:23 
OOEOOEOOCXOOOOEOOOOOOUE 2, OW FI F IIE IE E FEIE EIE IEEE 
SC_no: 2 
studentno: 19120000222 
courseno: col237 
teacherno: t01239 
score: NULL 
SC time: 2017 - 05 - 05 18:24:22 
2 rows in set (0.05 sec) 


16.2.3 从 文本 文件 执行 MySQL 命令 


通过 DOS 窗口 和 MySQL 控制 台 都 可 以 执行 MySQL 请 句 进行 一 般 交 互 。 例 如 ,将 
MySQL 语句 放 到 一 个 文件 中 ,然后 从 该 文件 中 进行 读 取 。 要 实现 这 种 方式 ,可 以 创建 一 个 
文本 文件 ,并 且 该 文件 中 包含 要 执行 的 语句 ,然后 进行 调用 。 

shell 命令 的 调用 格式 如 下 : 


shell> mysql database name < text file 


还 可 以 用 一 个 use database. name 语句 启动 文本 文件 。 此 时 ,不 需要 在 命令 行 中 指定 
数据 库 名 ,语法 如 下 : 


shell» mysql < text_file 
如 果 正 在 运行 MySQL ,可 以 使 用 source 或 \. 语句 执行 SQL 脚本 文件 ,语法 如 下 : 


mysql» source filename 
mysql» V. Filename 


MEGES 
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[5/16-10] 在 D 磁盘 下 创建 名 称 是 mytest 的 文本 文件 。 文 本 内 容 如 下 : 


use teaching; 
select  * from se course; 


select now(); 


在 DOS 窗口 中 执行 MySQL 命令 语句 ,指定 文本 文件 并 执行 该 文件 中 的 语句 。 
输出 结果 如 下 : 


C:\Users\Administrator > mysql <D:\mytest. txt — u root -p 
Enter password: ****** 


SC no  studentno Courseno teacherno score SC time 
1 19120000111 col236 t+01237 NULL 2017 - 05 - 01 18:40:23 

2 19120000222 Co1237 t01239 NULL 2017 - 05 - 05 18:24:22 
now() 


2017 - 06 - 29 20:07:48 
C:NUsersMdninistrator > 


16.3 MySQL 实验 中 的 常见 操作 


MySQL 数据 库 安装 完成 后 ,可 能 会 根据 实际 情况 更 改 MySQL 数据 库 的 某 些 配 置 。 一 
般 可 以 通过 手动 方式 更 改 MySQL 数据 库 的 某 些 配 置 。 手 动 更 改 方式 虽然 比较 困难 ,但 是 
这 种 配置 方式 更 加 灵活 。 

安装 MySQL 数据 库 时 提 到 将 MySQL 数据 库 安装 到 C 磁盘 下 ,文件 安装 在 C:\ 
Program Files\ MySQL\ MySQL Server 5. 7 目录 下 ,如 图 16-2 所 示 。 数 据 库 文件 安装 在 
C:\Documents and Settings\All Users\ Application Data (MySQL MMySQL Server 5. 7 H 
录 下 ,该 目录 下 包含 data 文件 夹 和 my. ini X fF. 

从 图 16-2 中 可 以 看 出 ,安装 文件 包含 多 个 文件 夹 和 my-default. ini 文件 。 其 中 ,bin X 
件 夹 下 都 是 可 执行 文件 ,例如 mysql. exe、mysqlld. exe 和 mysqladmin. exe 等 ; docs 文件 夹 
自 带 了 两 个 关于 mysql5.7 的 英文 说 明文 档 。include 文件 夹 下 都 是 头 文件 ,如 decimal. h, 
errmsg. h 和 mysql. h 等 ; lib 文件 夹 下 都 是 库 文件 .该 文件 夹 下 有 plugin 和 debug 两 个 文 
件 夹 ; share 文件 夹 下 是 字符 集 、 语 言 等 信息 。 
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图 16-2 MySQL 的 安装 文件 


my-default. ini 文件 里 面 存放 的 是 一 些 默 认 配 置信 息 , 而 数据 库 安装 目录 下 的 my. ini 
文件 才 是 真正 的 配置 文件 。 因 此 ,只 要 修改 my. ini 文件 中 的 内 容 就 可 以 达到 更 改 配 置 的 目 
的 。my. ini 文件 中 包含 了 大 量 的 内 容 , 下 面 介 绍 该 文件 时 会 去 掉 大 量 的 注释 内 容 , 然 后 从 
客户 端 配置 和 服务 器 端 配置 进行 介绍 。 

如 果 安 装 时 选择 的 配置 不 一 样 ,那么 配置 文件 就 会 稍 有 不 同 。 通 常情 况 下 ,经 常 修改 的 
是 默认 字符 集 、 默 认 存储 引擎 和 端口 等 信息 ,其 他 参数 修改 比较 复杂 ,一 般 不 进行 修改 。 另 
外 ,每 次 修改 参数 后 ,必须 重新 启动 MySQL 服务 才 会 有 效 。 

1. 客户 端 配置 

客户 端的 配置 非常 简单 , port 参数 表示 MySQL 数据 库 的 端口 ,默认 端口 是 3306 。 
default-character-set 参数 是 客户 端的 默认 字符 集 , 现 在 设置 的 参数 是 utf8。 如 果 想 要 更 改 
客户 端的 设置 内 容 , 可 以 直接 在 my. ini 文件 中 进行 更 改 ,部 分 配置 内 容 如 下 ; 


# Other default tuning values 
# MySQL Server Instance Configuration File 


# Generated by the MySQL Server Instance Configuration Wizard 
* 该 文件 是 使 用 MySQL. 配置 向 导 生 成 的 
# CLIENT SECTION 


# 下 面 将 会 是 客户 端的 各 个 参数 的 介绍 。[client] 和 [mysql] 都 是 客户 端的 


[client] 
no - beep 


* pipe 
# socket = mysql 
port = 3306 


[mysal] 
default - character - set = utf8 


2. 服务 器 端 配置 
与 客户 端 相 比 , 服 务 器 端的 配置 要 复杂 得 多 ,自动 生成 的 文件 内 容 是 通过 英文 解释 说 明 
的 ,下 面 通 过 中 文 对 相关 的 内 容 进行 了 解释 说 明 。 


# SERVER SECTION 


# 下 面 是 服务 器 端 各 个 参数 的 介绍 。[mysqlId] 表 示 下 面 的 内 容 属于 服务 器 端 

# server type=3 

[mysqld] 

* port 参数 表示 MySOL 数据 库 的 端口 ,默认 端口 是 3306 

port = 3306 

# basedir 参数 表示 MySOL 安装 路 径 ,此 处 显示 的 安装 路 径 为 了 磁盘 

# basedir = "C:/Program Files/MySQL/MySQL Server 5. 7/" 

* datadir 参数 表示 MySQL 数据 文件 的 存储 位 置 

datadir = "C:/Documents and Settings/All Users/Application Data/MySQL/MySQL Server 5.7/data\" 
# character - set - server 参数 表示 默认 的 字符 集 , 这 个 字符 集 是 服务 器 端的 


character - set - server = utf8 
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# default- storage - engine 参数 表示 默认 的 存储 引擎 ,存储 引擎 表示 数据 的 存储 方式 
default — storage 一 engine = INNODB 

# sql- mode 参数 表示 SQL 模式 的 参数 ,通过 这 个 参数 ,可 以 设置 检验 SOL 语句 的 严格 程度 
Sql- mode = "STRICT TRANS TABLES, NO_AUTO_CREATE USER, NO_ENGINE_SUBSTITUTION" 

# plugin- load 参数 表示 Windows 身份 验证 

# plugin- load = authentication windows. dll 

# 通用 查询 日 志和 慢 查 询 日 志 

log- output = NONE 

general- log- 0 

general log file = "WS. log" 

slow - query - log = 0 

slow_query_log_file = "WS— slow. log" 

long_query_time = 10 

* 二 进 制 日 志 

* log- bin 

# 错误 日 志 

log- error = "WS. err" 

* max connections 参数 表示 人 允许 同时 访问 MySQL 服务 器 的 最 大 连接 数 。 其 中 一 个 连接 将 保留 作为 
# 管 理 员 登录 

max connections = 100 

f query cache size 参数 表示 查询 时 的 缓存 大 小 。 缓 存 中 可 以 存储 以 前 的 SELECT 语句 查询 过 的 信 
# 息 , 遇 到 相同 的 查询 时 ,可 以 直接 从 缓存 中 取出 结果 

query_cache_size = 1M 

# table open cache 参数 表示 所 有 进程 打开 表 的 总 数 

table_open_cache = 2000 

* tmp table size 参数 表示 内 存 中 临时 表 的 最 大 值 

tmp table size= 5M 

# thread cache size 参数 表示 保留 客户 端 线 程 的 缓存 


thread cache size=9 


3. InnoDB 存储 引擎 使 用 的 参数 
InnoDB 是 MySQL 5. 7 数据 库 的 默认 存储 引擎 , my. ini 文件 中 还 包含 InnoDB 和 
MyISAM 存储 引擎 使 用 的 参数 。 下 面 的 内 容 是 InnoDB 存储 引擎 的 一 些 常用 参数 。 


# *** INNODB Specific options *** 
# innodb data home dir- 0.0 
# innodb additional mem pool size 
// 参 数 表示 附加 的 内 存 池 , 用 来 存储 InnoDB 表 的 内 容 

innodb additional mem pool size= 2M 
* innodb flush log at trx commit // 参 数 设置 提交 日 志 的 时 机 
innodb flush log at trx commit- 1 
# innodb log buffer size // 参 数 表示 用 来 存储 日 志 数据 的 缓冲 区 的 大 小 
innodb log buffer size- 1M 
* innodb buffer pool size 

// 表 示 缓 存 的 大 小 。InnoDB 使 用 一 个 缓冲 池 来 保存 索引 和 原始 数据 
innodb buffer_pool_size= 8M 


# innodb log file size // 人 参数 表示 日 志文 件 的 大 小 
innodb log file size= 48M 
# innodb thread concurrency // 参 数 表 示 在 InnoDB 存储 引擎 允许 的 线程 最 大 数 


innodb thread concurrency - 8 


这 里 只 列 出 了 InnoDB 存储 引擎 的 一 些 常用 参数 。 当 然 ,my. ini 文件 中 的 内 容 并 不 是 
前 面 所 列 出 的 那些 。my. ini 文件 中 的 内 容 是 英文 的 ,上 面 加 上 了 中 文 说 明 , 可 以 找到 安装 
目录 下 的 my. ini 文件 并 打开 查看 其 所 有 内 容 。 


16.4 常见 的 错误 代码 和 处 理 


在 客户 端的 控制 台 执行 语句 时 ,如果 执行 的 语句 不 合法 或 者 错误 , 则 会 输出 有 关 的 错误 
信息 。 例 如 ,在 命令 中 执行 “select month(current_data) ; ?语句 时 出 现 1054 错误 。 
代码 和 输出 结果 如 下 : 


mysql» select month(current data); 
ERROR 1054 (42S22) : Unknown column 'current data ' in 'field list" 


上 述 提示 1054 ,表示 current. data 列 不 存在 。 除 了 这 些 错 误 外 ,在 执行 
会 出 现 其 他 的 错误 , 表 16-7 列 出 了 一 些 常见 的 错误 代码 ,并 且 对 这 些 代码 进 


语句 时 可 能 还 
行 了 说 明 。 在 


实验 过 程 中 ,可 以 根据 错误 代码 查看 错误 原因 。 


错误 代码 


表 16-7 执行 MySQL 语句 时 的 常见 错误 代码 
说 H 





1005 


创建 表 失 败 





1006 


创建 数据 库 失 败 





1007 


数据 库 已 存在 ,创建 数据 库 失败 





1008 


数据 库 不 存在 ,删除 数据 库 失 败 





1009 


不 能 删除 数据 库 文件 导致 删除 数据 库 失 败 





1010 


不 能 删除 数据 目录 导致 删除 数据 库 失败 





1011 


删除 数据 库 文件 失败 





1012 


不 能 读 取 系统 表 中 的 记录 





1045 


不 能 连接 数据 库 , 用 户 名 或 密码 错误 





1048 


字段 不 能 为 空 





1049 


数据 库 不 存在 





1050 


数据 表 已 存在 





1051 


数据 表 不 存在 





1054 


字段 不 存在 





1065 


无 效 的 SQL 语句 ,SQL 语句 为 空 





1081 


不 能 建立 Socket 连接 





1114 


数据 表 已 满 , 不 能 容纳 任何 记录 





1116 


打开 的 数据 表 太 多 





1129 


数据 库 出 现 异 常 ,请 重启 数据 库 





1130 


连接 数据 库 失 败 , 没 有 连接 数据 库 的 权限 





1133 


数据 库 用 户 不 存在 





1141 


当前 用 户 无 权 访问 数据 库 





1142 


当前 用 户 无 权 访问 数据 表 





1143 


当前 用 户 无 权 访问 数据 表 中 的 字段 





1146 





数据 表 不 存在 
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续 表 
错误 代码 说 明 
1147 未 定义 用 户 对 数据 表 的 访问 权限 
1149 SQL 语句 语法 错误 
1158 网 络 错误 ,出 现 读 错误 ,请 检查 网 络 连接 状况 
1159 网 络 错误 , 读 超 时 ,请 检查 网 络 连 接 状 况 
1160 网 络 错误 ,出 现 写 错误 ,请 检查 网 络 连 接 状 况 
1161 网 络 错误 , 写 超时 ,请 检查 网 络 连 接 状 况 
1162 字段 值 重复 ,入 库 失败 
1169 字段 值 重复 ,更 新 记录 失败 
1177 打开 数据 表 失 败 
1180 提交 事务 失败 
1181 回 滚 事务 失败 
i205 当前 用 户 和 数据 库 建立 的 连接 已 到 达 数 据 库 的 最 大 连接 数 ,请 增 大 可 用 的 数 
据 库 连接 数 或 重启 数据 库 
1216 外 键 约束 检查 失败 ,更 新 子 表 记录 失败 
1217 外 键 约束 检查 失败 ,删除 或 修改 主 表 记录 失败 
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MySQL 数据 库 的 基本 操作 相对 简单 一 些 , 实 验 中 常用 到 的 工具 主要 包括 安装 完成 后 
自 带 的 命令 工具 ,这 些 命令 多 数 需要 记忆 ,操作 时 显得 比较 复杂 和 麻烦 。 

在 MySQL 中 还 可 以 使 用 图 形 界面 管理 工具 方便 地 进行 数据 库 操作 。MySQL 的 图 形 
管理 工具 有 很 多 ,常用 的 有 MySQL GUI Tools, MySQL Workbench, phpMyAdmin 和 
Navicat 等 。 教 材 中 主要 使 用 MySQL Workbench 工具 进行 MySQL 数据 库 的 可 视 化 操作 。 
MySQL Workbench 是 一 款 专 为 MySQL 设计 的 E-R/ 数 据 库 建 模 工 具 。 

本 章 将 介绍 Navicat 和 phpMyAdmin 可 视 化 工具 的 主要 应 用 。 


17.1 可 视 化 工具 Navicat 软件 的 使 用 


Navicat 软件 是 一 套 快 速 、 可 靠 且 价格 适宜 的 MySQL. 数据 库 管理 和 开发 工具 。 
Navicat 易学 易 用 ,支持 中 文 ,特别 适合 初学 者 进行 数据 库 管理 操作 ,也 有 人 免费 版 本 提供 。 

Navicat 适用 于 Windows 和 Linux 等 多 种 操作 系统 ,可 以 让 用 户 连接 到 任何 本 机 或 远 
程 服务 器 ,提供 一 些 实用 的 数据 库 工具 如 数据 操作 ,数据 传输 、 导 入 导出 、 备 份 还 原 、 报 表 创 
建 工具 及 计划 以 协助 管理 数据 等 。 

Navicat 工具 包含 多 个 成 员 ,主要 包括 Navicat Premium, Navicat for MySQL, Navicat 
for SQL Server 和 Navicat for Oracle 等 。 可 以 从 Navicat 的 官方 网 站 https://www. 
navicat. com /en/download /navicat-for-mysql 下 载 不 同 操作 系统 下 的 Navicat 版 本 。 

Navicat 是 一 个 可 多 重 连接 的 数据 库 管 理工 具 , 它 可 连接 到 MySQL, Oracle, 
PostgreSQL SQLite, SQL Server 等 数据 库 ,使 得 管理 不 同类 型 的 数据 库 更 加 方便 。 

Navicat 符合 专业 开发 人 员 的 所 有 需求 ,对 维护 数据 库 服 务 器 的 新 手 来 说 又 相当 容易 学 
习 , 它 具有 极 完备 的 图 形 用 户 界面 ,可 让 用 户 简 便 地 以 安全 且 简 单 的 方法 创建 组织 ,访问 和 
共享 信息 。 


17.1.1 Navicat 安装 和 连接 


1. Navicat 的 安装 

首先 从 指定 网 站 下 载 Navicat 软件 ,例如 mysqlen_11. 1. 13. 0. exe 软件 ,然后 就 可 以 开 
始 安装 Navicat 软件 了 。 

CD 双击 安装 文件 mysqlen_11. 1. 13. 0. exe, 进 入 安装 欢迎 界面 如 图 17-1 所 示 。 单 击 
“下 一 步 ” 按 钮 ,进入 “许可 证 ”界面 ,如 图 17-2 所 示 。 

(2) 选择 单 选 按钮 “我 同意 ”, 单 击 “ 下 一 步 ” 按 钮 ,进入 “选择 安装 文件 夹 " 界 面 , 单 击 “ 浏 
览 ” 按 钮 ,可 以 选择 合适 的 路 径 , 如 图 17-3 所 示 。 
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欢迎 安装 PremiumSoft Navicat for 


MySQL 
- 即将 在 您 的 计算 机 上 安装 PremiumSoft Navicat 11.1 for 
MySQL« 


建议 您 关闭 所 有 的 运行 程序 后 继续 。 
点 击 下 一 步 继续 , 点 击 取 消 取消 安装 。 


Navicat 
for MySQL 
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本 证 
在 继续 前 ， 请 阅读 以 下 重要 信息 : 





请 阅读 版 权 许可 ， 继 续 前 必须 同意 其 中 的 条 敦 * 
[End-User License Agreement for PremiumSoRt Navicat = 
IMPORTANT: THIS SOFTWARE END USER LICENSE AGREEMENT CEULA) (7) 


[IS A LEGAL AGREEMENT BETWEEN YOU (EITHER AN INDIVIDUAL OR. IF 
PURCHASED OR OTHERWISE ACQUIRED BY OR FOR AN ENTITY. AN 














17-2 安装 许可 界面 
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选择 安装 文件 夫 
在 哪里 安装 PremiumSoft Navicat for MySQL? 











b 安装 程序 将 在 以 下 文件 来 安装 PremiumSoft Navicat for MySQL。 
点 击 下 一 步 雏 续 。 答 改变 安装 文件 来 点 击 浏览 。 
E Program Fies ‘Premium Soft Navicat for MySQL 0 





至 少 需要 739 MB 磁盘 空间 。 





E58 -R—bM BAO 
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(3) 单 击 “下 一 步 ? 按 钮 ,进入 选择 “选择 开始 目录 ?界面 ,依次 单 击 * 下 一 步 ? 按 钮 ,可 以 
进入 “准备 安装 ”界面 ,如 图 17-4 所 示 。 

(4) 单 击 “下 一 步 ?按钮 ,进入 * 选 择 额外 任务 ”界面 ,可 以 在 此 选择 是 否 创建 桌面 图 标 ， 
如 图 17-5 所 示 。 





安装 程序 - PremiumSoft Navicat for MySQL LETE 3T 
选择 开始 目录 
在 哪里 创建 快 接 方式 ? » 


Ll ssenscurenenaos- 








点 击 下 一 步 继续 。 谷 选择 别 的 目录 ， 点 击 浏览。 
TEST Wao 























图 17-4 选择 开始 目录 
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选择 额外 任务 
您 想 执行 什么 颗 外 任务 9 


Lola iid PremiumSoft Navicat for MySQL 时 执行 的 额外 任务 ， 再 


Additional icons: 
(V) Greate a desktop con 
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(5) 单 击 “ 下 一 步 ” 按 钮 ,进入 “准备 安装 ”界面 ,如 图 17-6 所 示 。 单 击 “ 安 装 ” 按 钮 ,进入 
安装 过 程 。 如 图 17-7 所 示 , 单 击 “ 完 成 ”按钮 , 即 可 完成 Navicat 软件 的 安装 。 
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准备 安装 
安装 程序 即将 安装 PremiumSoft Navicat for MySQL。 





点 击 安装 继续 安装 ， 点 击 上 一 步 检查 并 改变 设置 。 


安装 文件 夹 : 
C:\Program Fies\PremiumSoft\Navicat for MySQL 
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安装 程序 - PremiumSoft Navicat for MySQL. 





完成 PremiumSoft Navicat for 
ySQL 安装 向 导 


M L 安装 向 

二 PremiumSoft Navicat for MySQL 的 支 装 已 完成 。 点击 图 标 可 
执行 本 程序 。 
点 击 完 成 退出 安装 向 导 。 


Navicat 


for MySQL 





17-7 “完成 安装 


2. Navicat 的 连接 
CD 选择 “开始 ”>“ 所 有 程序 ”命令 ,按照 如 图 17-8 所 示 执 行 Navicat for MySQL 命令 ， 
即 可 进入 如 图 17-9 所 示 的 Navicat 初始 界面 。 


di MySQL 
Ji Netcore RSS PES (CU) 
Ji PremiumSoft 
Jj. Navicat for MySQL 
Lj License Agreement 
L) Navicat Support Center 
LÌ Online Regi: 
4$ Uninstall Navicat for MySQL 
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文件 昌 EV IAD SOW 帮助 (H) 


z2 mgacrszeesc 


E: 卫 打 开 表 @) ke) Taeko TMO 司 导入 向 号 sj 

































































图 17-9 Navicat 的 初始 界面 


(2) 在 如 图 17-9 所 示 的 Navicat 软件 初始 界面 中 ,可 以 观察 到 Navicat 软件 的 菜单 栏 、 
工具 栏 和 连接 两 个 操作 窗口 。 菜 单 栏 中 包括 “文件 “查看 “工具 “窗口 "和 “帮助 "常用 操作 
命令 菜单 。 工 具 栏 中 包括 “连接 ”管理 用 户 “ 表 ”视图 ”存储 过 程 " 和 “事件 "等 数据 库 对 象 
的 常用 操作 提示 o 

(3) 单 击 工 具 栏 中 的 “连接 ”按钮 ,进入 如 图 17-10 所 示 的 “连接 ”界面 。 在 如 图 17-10 所 


示 的 界面 中 输入 连接 名 等 选项 ,然后 单 击 “ 连 接 测试 ?按钮 ,测试 连接 成 功 后 就 可 以 使 用 
Navicat 软件 实现 MySQL 数据 库 的 可 视 化 操作 了 。 


ET Wi 
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17.1.2. 数据 库 管理 的 基本 操作 


1. 打开 数据 库 
CD 右 击 “连接 ”窗口 的 “连接 ”图 标 ,如 图 17-11 所 示 , 在 弹出 的 菜单 中 执行 “打开 数据 
E MO ,系统 弹 出 如 图 17-12 所 示 的 “打开 数据 库 ” 对 话 框 。 





文件 查看 IR ED 帮助 


FE 





事件 aus . 
连接 Timo 28e TARAVU EO 






























































agim ooo E waz-mvsal_ 用户 : root 
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(2) 在 如 图 17-12 所 示 的 “打开 数据 库 ” 对 话 框 中 输入 指定 数据 库 teaching, 单 击 “ 确 定 ” 
按钮 ,软件 即 可 打开 teaching 数据 库 , 即 teaching 变 成 当前 数据 库 ,在 图 中 的 连接 窗口 中 呈 
现 亮 色 。 同 时 ,工具 栏 中 的 相关 数据 库 对 象 图 标 ,如 “ 表 ” 视 图 “存储 过 程 “ 事 件 “ 查 询 ” 和 
“备份 ”等 ,也 变 成 可 操作 的 状态 了 。 

















Cae )( ma 
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2. 表 的 管理 
(1) 在 “连接 ”窗口 中 , 单 击 数据 库 teaching 前 面 的 “十 ”号 ,展开 teaching 数据 库 , 单 击 
“ 表 ” 后 ,界面 如 图 17-13 所 示 。 
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(2) 选择 student 表 , 单 击 工具 栏 中 的 “打开 表 ? 按 钮 ,或 者 右 击 student d ,在 弹出 的 菜 
单 中 执行 “打开 表 ” 命 令 , 即 可 显示 如 图 17-14 所 示 的 student 表 的 浏览 状态 。 

G) 在 此 状态 下 ,还 可 以 对 student 表 进 行 如 导入 、. 导 出、 创建 视图 等 操作 。 

3. 管理 存储 过 程 

CD 单 击 工具 栏 中 的 “存储 过 程 ”按钮 ,如 图 17-15 所 示 ,可 以 查看 teaching 数据 库 中 的 
存储 过 程 。 

(2) 在 此 窗口 中 ,可 以 实现 创建 .设计 和 删除 存储 过 程 的 操作 。 可 以 通过 工具 栏 按钮 进 
行 操作 ,也 可 以 通过 快捷 菜单 执行 相关 命令 进行 操作 。 

(3) 类 似 的 如 视图 、 事 件 、 查 询 、 报 表 和 触发 器 等 都 可 以 在 此 窗口 中 进行 管理 操作 。 







































































图 17-14 浏览 表 



























































xt € IA 
» 
时 z[&3gsm 
连接 TAA mm me] 事件 xw wk an Hms = 
连接 Grec B mA CR EACH) 4 
里 teaching. ^ 
| 8 & 
| [m bef after 
T] course 
- 国 de teacher 
T] mytest 
-E score 
| [i soret 
T] se course 
TT] stu score. 
| TT] stu. totall 
TI] student 
-加 studento1 
T) teach course. 
T] teacher 
paama - 
E , 
BER 1 43S | BP root 
图 17-15 管理 存储 过 程 
4. 备份 管理 


CD. 单 击 图 17-15 所 示 的 工具 栏 中 的 “备份 ”按钮 ,进入 如 图 17-16 所 示 的 “创建 备份 ”对 
话 框 。 

(2) 单 击 “开始 ?按钮 ,系统 就 自动 备份 数据 库 teaching, 备 份 信息 如 图 17-17 所 示 。 执 
行 完毕 保存 备份 即 可 。 


5. 导 人 导出 管理 

(1) 数据 的 导入 导出 是 针对 表 数 据 进行 的 操作 。 从 打开 数据 库 teaching 的 界面 的 工具 
栏 中 可 以 找到 导入 、 导 出 按钮 ,也 可 以 从 图 17-13 中 的 右 击 菜单 中 执行 导入 导出 命令 。 

(2) 执行 “导出 向 导 ” 命 令 , 进 入 如 图 17-18 所 示 的 “导出 向 导 ” 对 话 框 ,例如 选择 txt 


类 型 。 
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注意 : 这 将 只 备份 表 和 数据 。 不 包括 查询 和 报表 。 






































F 


向 导 可 以 让 你 指定 如 何 号 出 数据 的 细节 。 你 要 使 用 哪 一 种 号 出 格式 ? 


den 
© Paradox rf (*.db) © QuattroPro Xf (*-wa1) 


© DBase Sr (^b) OSLER Cs) 
[EC] Co 文件 Caa 
四 mt 文件 Chtm=htn © Ms access AHIRE ndo) 
| Osea Co) © MS Windows IRI 
© Exc c (rod) O Rih Tet st (ott 
四 word 文件 Cdog © pss 格 式 (say) 
O srk PHD Cr.) © Adobe Acrobat Zf (*.pdf) 
© or GHRAD Cd O re BIRA CaN 
© Lotus 1:2-3 tf C) 


Cer r) CJ- ] id] 
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(3) 单 击 “ 下 一 步 ” 按 钮 ,进入 如 图 17-19 所 示 的 选择 导出 表 和 导出 文件 的 对 话 框 中 。 


例如 ,分 别 选 择 student, course 和 score 三 个 表 , 并 指定 导出 文件 的 存储 路 径 。 如 果 单 击 “ 高 
级 ”按钮 ,可 以 为 导出 文件 选择 编码 格式 和 时 间 戳 记 , 如 图 17-20 所 示 。 
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(4) 单 击 “下 一 步 "按钮 ,进入 如 图 17-21 所 示 的 “选择 导出 列 ” 对 话 框 ,在 此 可 以 对 导出 
表 进 行 选择 全 部 或 部 分 列 的 操作 。 























107 
[NIE 四 Æ>) 
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(5) 单 击 “下 一 步 ?按钮 ,进入 如 图 17-22 所 示 的 “定义 额外 选项 ”对 话 框 ,在 此 可 以 选择 
是 否 “ 包 含 列 标题 “过 到 错误 继续 ”以 及 定 界 符 、 日 期 分 隔 符 等 选项 。 









|| EEES 












































Ed 17-22 定义 额外 选项 
(6) 单 击 “下 一 步 ?按钮 ,进入 如 图 17-23 所 示 的 “信息 收集 完成 ”对 话 框 。 


Emm —— mmm x7 





| 我 们 已 收集 全 部 向 导 号 出 数据 Bj 所 需 的 讯息 。 点 击 [开始 ] 按 岂 开始 导出 
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CD) 单 击 “开始 ?按钮 , 即 可 完成 选择 数据 表 的 导出 操作 ,如 图 17-24 所 示 。 

(8) 如 果 想 进行 导入 操作 ,可 以 选择 图 17-13 所 示 的 “导入 向 导 ” 命 令 , 进 入 如 图 17-25 
所 示 的 “导入 向 导 ” 对 话 框 ,按照 向 导 说 明 , 就 能 够 实现 将 其 他 类 型 数据 导入 到 当前 数据 库 中 
的 操作 。 导 入 过 程 与 导出 操作 类 似 , 在 此 不 再 袭 述 。 

Navicat 软件 是 MySQL 数据 库 的 一 个 性 能 优良 的 可 视 化 管理 工具 ,功能 强大 ,支持 中 
文 操作 。 在 实验 过 程 中 利用 Navicat 软件 操作 MySQL 数据 库 会 收 到 很 好 的 效果 。 





p 


|| 我 已 收 集 全 部 向 导 导 出 数据 所 在 的 讯息 。 点 击 [开始 ] HARESH. 





[Exp] 
[Exp] Getting. 
[Exp] 
[Exo] 
[Exo] 
[Exo] 
[Ep] 
[Exo] 
[Exp] Finished 


Msg] 
[Msg] 
[Msa] 
[Msa] 
[Msg] 
Msg] 
[Msg] 
Mso] 
Msg] 


miere -Text fie 
and Exporting 
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这 个 向 导 允 许 你 指定 如 何 导入 数据 的 明细 。 你 要 选择 哪 种 数据 导入 格式 ? | 


导入 类 型 

© Paradox Xz Pt (*.db) 

© DBase Sr f (*.dbf) 
OS Cb) 

© HTML Sr f C*-htm;*- html) 
© Excel rf (ds) 

© Excel 2007 fF (*ex) 
© Lotus 1-2-3 SC PF ("wk 1) 
© QuattroPro Ief (*.wq1) 
Om ZP Com) 

© MS Access 数据 诛 (*.mdb) 
© oc 








[s E 





ts | klea) (omne 























图 17-25 导入 向 导 


17.2 R LE phpMyAdmin 软件 


phpMyAdmin 是 一 个 用 PHP 编写 的 ,可 以 通过 互联 网 控制 和 操作 的 MySQL 数据 库 。 
通过 phpMyAdmin 完全 可 以 对 MySQL 数据 库 进 行 操作 ,例如 建立 ` 复 制 和 删除 数据 等 。 
使 用 Web 接口 可 以 成 为 一 个 应 用 简易 方式 输出 MySQL 语法 的 较 好 途径 ,尤其 是 要 处 理 海 


量 信息 的 查询 与 分 析 更 为 方便 。 
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17.2.1 phpMyAdmin 工具 的 安装 和 配置 


phpMyAdmin 是 最 常用 的 MySQL 维护 工具 ,是 用 PHP 开发 的 基于 Web 方式 架构 在 
网 站 主机 上 的 MySQL 管理 工具 ,支持 中 文 , 管 理 数据 库 非 常 方便 。 可 以 在 其 官方 网 站 
https://www. phpmyadmin. net/downloads/ 下 载 最 新 版 本 的 phpMyAdmin 工具 。 

(1) 下 载 phpMyAdmin 软件 。 到 官方 网 址 下 载 phpMyAdmin 软件 ,建议 使 用 多 国语 言 
版 ,这 样 才 会 出 现 简体 中 文字 符 。 例 如 .下载 phpMyAdmin-4. 7. 3-all-languages. zip 版 本 。 

(2) 配置 phpMyAdmin。 下 载 的 phpMyAdmin 解压 ,并 将 解压 出 来 的 文件 夹 改名 为 
phpMyAdmin, 然 后 查找 到 此 文件 夹 的 /phpMyAdmin/libraries 文件 夹 下 的 config. default. 
php, 复 制 到 /phpMyAdmin 文件 夹 ,并 重 命名 为 config. inc. php. 

(D 用 文本 方式 打开 config. inc. php ,执行 “编辑 ”~“ 查 找 ” 命 令 。 


查找 下 列 文本 : 
$ cfg[ 'PmaAbsoluteUri'] = ''; 
将 其 改 成 
$ cfg[ 'PmaAbsoluteUri'] = 'http://localhost/phpnyadmin'; 
查找 下 列 文本 : 


$ cfg[ 'Servers'][ $ i]['auth type'] = 'cookie'; 


把 config PX http. Bl 





$ cfg[ 'Servers'][ $ i]['auth type'] = 'http'; 
// 改 成 http 后 ,就 可 以 像 登录 路 由 器 那样 ,出 现 一 个 登录 对 话 框 

然后 保存 退出 。 

© 对 于 Windows 系统 : 加 载 mbstring 解决 方法 。 利 用 文本 方式 PHP 的 配置 文件 
php. ini。 

查找 下 列 文本 : 

;extension- php mbstring.dll 
将 其 改 成 

extension = php_mbstring. dll 


然后 保存 退出 。 

(3) phpMyAdmin 软件 的 运行 。 本 地 配置 完毕 后 ,将 phpMyAdmin 软件 上 传 到 服务 器 
或 虚拟 服务 器 上 的 Web 的 根 文件 夹 htdocs( 有 些 服务 器 文件 夹 httproot) 中 。 用 浏览 器 输 
入 地 址 ,例如 : http://localhost/phpmyadmin/( 如 果 默 认 端 口号 80 被 占用 ,可 以 改 成 其 他 
端口 号 ,如 81。 输 入 网 址 http://localhost:81/phpmyadmin/ 即 可 ) ,就 会 跳出 一 个 输入 用 户 
名 和 密码 的 对 话 框 , 如 图 17-26 所 示 , 输 入 MySQL 的 账号 和 密码 即 可 开始 利用 
phpMyAdmin 软件 操作 MySQL 数据 库 。 





需要 进行 身份 验证 


服务 器 htpy/localhost81 要 求 用 户 输入 用 户 名 和 密码 . 最 


SEER : phpMyAdmin localhost, 





用 户 名 : 











E: 
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17.2.2 phpMyAdmin 工具 的 常用 操作 


利用 phpMyAdmin 软件 操作 MySQL 数据 库 , 包 括 数 据 库 、 表 、 存 储 过 程 、 函 数 程序 . 触 
发 器 和 事件 等 对 象 的 创建 和 使 用 ,管理 用 户 账 户 和 权限 ,进行 数据 备份 和 数据 恢复 等 ,可 以 


实现 对 MySQL 数据 库 的 快捷 方便 的 操作 管理 。 

1. 登录 phpMyAdmin 软件 

(D 在 登录 phpMyAdmin 的 身份 验证 窗口 中 
输入 MySQL 的 账号 和 密码 ,如 图 17-27 所 示 , 单 
击 “ 登 录 ” 按 钮 ,进入 如 图 17-28 所 示 的 初始 界面 。 

(2) 在 如 图 17-28 所 示 的 页 面 中 .用户 修改 密 
码 、 选 择 服务 器 字符 排序 规则 和 语言 等 ,也 可 以 操 | 
作 数 据 库 、 执 行 SQL 语句 、 查 看 运行 状态 .管理 账 | 
户 ,进行 数据 的 导入 导出 ,以 及 查看 字符 集 、 变 量 、 


需要 进行 身份 验证 x 


服务 器 http://localhost:81 要 求 用 户 输入 用 户 名 和 密码 。 服 
务 器 提示 : phpMyAdmin localhost, 


用 户 名 : root 
EB: 06M 


| e || ws | 








二 进 制 日 志 、 引 擎 和 插件 等 。 
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performance, schema. 外 观 设置 
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图 17-28 phpMyAdmin 软件 的 初始 界面 
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2. 管理 数据 库 对 象 


CD 数据 表 管 理 。 如 图 17-28 所 示 , 展开 “ 表 收 藏 夹 ” 下 的 teaching 数据 库 , 单 击 
teaching 数据 库 的 “ 表 ”, 进 入 如 图 17-29 所 示 的 表 的 操作 窗 体 中 ,可 以 看 到 该 数据 库 下 的 所 
有 表 。 此 时 ,可 以 对 每 一 个 表 进 行 浏览 数据 ,修改 结构 ,搜索 记录 插入 记录 、 清 空 记录 、 删 除 


记录 等 操作 ,也 可 以 单 击 “ 表 ”文件 夹 下 的 “新 建 "命令 创建 新 表 。 
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(2) 表 结 构 的 管理 。 单 击 一 个 表 , 如 course, 即 可 进入 如 图 17-30 所 示 的 表 结 构 修 改 页 


面 。 此 时 ,可 以 对 course 表 中 的 列 进行 编辑 修改 、 复 制 和 删除 等 操作 。 























j teaching ser vV courseno cname type period exp term 
Bo se D A 编辑 x: 复制 Q MIÈ c05103 高 等 数学 必修 64 16 2 
a O J RR xe 夏 制 Q 删除 c05109 5 语言 。” 必修 48 16 2 
D J 编辑 zi 复制 Q WIS c05127 数据 结构 必修 64 16 2 
cg Sg O p 编辑 gc EH Q 删除 c05138 软件 工程 选修 48 8 5 
JÄ bef, after z : 
2s course D J 编辑 Rc Et) @ MIR c05139 建 模 DIL 选修 48 12 
Ji de teacher O J 编辑 xe 复制 @ 删除 c05141 WIN 设计 选修 48 8 8 
T AUN O 2 编辑 3e SS] @ MIR cos WEB 语言 选修 3 8 8 
jf scorel O p 编辑 gc 夏 制 Q 删除 c06108 机 械 制图 必修 60 8 2 
Ji se_course D J 编辑 xe EH Q WIR c06127 机 械 设计 必修 64 8 3 
G E O J 编辑 Rc 复制 Q MIS c06172 BEIZ 选修 42 16 6 
JÄ stu_score D A 编辑 Rc Bi] Q NT c08106 经 济 法 ve 48 0 了 
carian O Q5 Es @ MI c08123 PIPES iE 40 0 5 
Ji teacher 
B tenete course t 0 $5 A9. AA EN Que pos 
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(3) 存储 过 程 管理 。 单 击 teaching 数据 库 下 的 “存储 过 程 ”, 展 开 存储 过 程 列表 ,可 以 对 
存储 过 程 进行 操作 。 单 击 存储 过 程 auto_cno, 如 图 17-31 所 示 , 可 以 修改 存储 过 程 auto_cno 


的 所 有 选项 参数 ,如 存储 过 程 名 、 代 码 等 内 容 。 



































zum -| ERES [Puto_cno 
JB | 类 型 Í PROCEDURE v 
«6 




















(m iss 方向 。 名 字 cm —km/É 选项 
eB auto. 
Dans C 添加 参数 al 
[a do àr| 1 begin 
2 start transaction; 
[d do. ot 3 delete from course where courseno-' c05103 ; 
a do. ax| 4 select * from course where  courseno- cOS103 ; 
handl 5 rollback; 
本 | B select * from course where courseno=’ c05103 ; 
eg T end 
[inox :| ex 
| proc. | 
[aĝ proc. 
Ber n 
[ B selec 
[d solat z 
T As | 关闭 
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3. 设计 器 的 使 用 

使 用 phpMyAdmin 软件 可 以 实现 MySQL 的 一 般 操作 : 如 导入 导出 数据 .创建 索引 和 
实现 参照 完整 性 约束 、 使 用 查询 等 ,还 能 够 管理 视图 .存储 过 程 、 存 储 函 数 、 触 发 器 .事件 .用 
户 、 权 限 , 以 及 备份 与 恢复 数据 库 等 。 

另外 ,phpMyAdmin 软件 的 设计 器 的 功能 也 很 强大 。 

(1) 选择 数据 库 teaching, 在 工具 栏 中 单 击 “ 设 计 器 ”按钮 , 窗 体 中 就 会 显示 数据 库 
teaching 中 的 所 有 表 和 视图 的 结构 ,如 图 17-32 所 示 。 
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# daily : float (3, 1) 
# final : float (3, 1) 








courseno : char( 
O cname : char(6) 
© department : char (16) 







O studentno : char (11) 
8 courseno : char (6) 
© teacherno : char(6) 
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图 17-32 利用 设计 器 管理 数据 库 
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(2) 在 图 17-32 的 右 侧 窗口 中 ,可 以 观察 到 工具 栏 ,展开 工具 栏 , 如 图 17-33 所 示 , 通 过 
该 工具 栏 ,可 以 对 当前 窗口 中 的 表 、 视 图 等 进行 操作 。 

(3) 执行 工具 栏 的 第 一 条 “show/hide tables list” 命 令 , 可 以 在 窗 体 右 侧 显 示 数 据 库 
teaching 中 的 所 有 表 和 视图 ,如 图 17-34 所 示 ,在 此 可 以 通过 列表 前 的 选择 按钮 选择 表 结 构 
是 否 在 窗 体 中 显示 ,以 此 可 以 在 表 设 计 器 中 实现 对 表 和 视图 的 相关 操作 。 











O Show/Hide tables list 











€  teaching.bef after 


加 SEI * teaching.course 

Là New page O teaching.course avg 

打开 页 面 LJ teaching.de teacher 
O teaching.mytest 

datum |J teaching. score 

园 保 存 页 面 为 | teaching.scorel 


LJ teaching.se course 
Delet c - 

Delete parez 回 teaching. student 

D ssa LJ teaching. student01 

山 Create relationship 日 teaching.stu score 

|J teaching.stu scorel 











O AREITHFA 0) teaching.stu totall 
O 重新 载 入 [O teaching.stu view2 
Quam O teaching. teacher 

LJ teaching.teach course 
Omm, 直接 连接 QO teaching.teach viewl 
Q 对 齐 网 格 [ teaching. teach_view2 
O 全 部 收缩 /展开 teaching.v_avestu 

LJ teaching.v dept 
O 反 向 收缩 /展开 O teaching.v sex 
Bi Toggle relationship lines L mea ins 
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MySQL Workbench , phpMyAdmin 和 Navicat 软件 是 目前 在 操作 MySQL 数据 库 时 常 
用 的 可 视 化 操作 工具 ,在 实验 过 程 中 ,可 以 选择 符合 环境 要 求 的 软件 使 用 。 其 中 
phpMyAdmin 软件 需要 在 PHP 环境 下 运行 和 操作 。 
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学 习 MySQL 数据 库 需要 在 掌握 部 分 理论 内 容 的 同时 进入 实验 环节 。 只 有 在 熟悉 
MySQL 的 运行 环境 的 基础 上 进行 实验 操作 ,才能 实现 培养 学 生 应 用 创新 能 力 ,以 提高 学 生 
的 数据 库 设计 、 管 理 和 操作 的 水 平 。 

本 课程 实验 的 学 时 数 可 安排 32 学 时 左右 , 共 安 排 16 个 实验 。 任 课 教 师 可 根据 实际 需 
要 对 实验 内 容 进行 摘 选 或 补充 。 讲 课 与 上 机 的 课时 比例 应 该 控制 在 3 : 2 左右 。 


18.1 MySQL 5.7 实验 指导 


1. 上 机 实验 的 目的 和 要 求 

学 习 MySQL 数据 库 应 当 在 达到 能 够 独立 地 创建 和 组 织 数据 库 ` 独 立 上 机 调试 程序 和 
分 析 结果 的 目标 ,进一步 加 深 对 MySQL 数据 库 的 有 关 理 论 的 理解 及 编程 的 基本 技能 的 提 
高 。 所 有 计算 机 类 课程 都 要 求实 践 性 经 验 ,没有 足够 的 上 机 实践 ,学 好 MySQL 数据 库 是 不 
可 能 的 。 

上 机 实验 的 目的 不 仅仅 是 为 了 验证 教材 和 讲课 的 内 容 或 者 验证 自己 所 编程 序 的 正确 与 
和 否 , 更 重要 的 是 通过 实际 题目 的 上 机 实验 ,可 以 提高 动手 能 力 、 提 高 分 析 问 题 和 解决 问题 的 
能 力 , 最 终 能 够 达到 举一反三 的 自主 学 习 效 果 , 以 至 于 将 来 能 够 在 实际 的 软件 开发 过 程 中 具 
有 创新 能 力 。 

具体 来 说 ,上 机 实验 的 目的 应 该 从 以 下 几 个 方面 进行 理解 。 

CD 加 深 对 MySQL 语言 基础 的 理解 。 对 于 初学 者 来 说 ,仅仅 通过 课堂 教学 ,很 难 将 课 
程 要 求 的 内 容 记 住 并 理解 透彻 ,尤其 是 比较 琐碎 的 语言 要 素 , 如 数据 类 型 .运算 符 、 系 统 函 数 
和 灵活 多 变 的 规则 等 。 只 有 通过 多 次 上 机 ,在 实验 中 不 断 探索 .思考 ` 归 纳 和 总 结 ,才能 够 熟 
练 地 掌握 相关 内 容 。 通 过 实验 可 以 快速 地 掌握 语法 规则 、 验 证 自己 的 能 力 、 加 深 自己 对 数据 
库 理 论 的 认识 。 

(2) 了 解 和 熟悉 MySQL 语言 的 环境 。 一 个 程序 必须 在 一 定 的 硬件 和 软件 环境 下 才能 
运行 。 使 用 者 应 该 了 解 , 为 了 运行 一 个 MySQL 程序 需要 哪些 必要 的 外 部 条 件 ( 例 如 硬件 配 
TE ,软件 配置 ), 可 以 利用 哪些 软件 的 功能 来 帮助 自己 开发 数据 库 。MySQL 中 几乎 所 有 的 
基本 操作 都 可 以 通过 可 视 化 工具 来 实现 。MySQL 用 户 的 数据 文件 .SQL 语言 文件 的 存储 
也 应 该 设置 固定 的 路 径 ,防止 出 现 文件 存放 位 置 混乱 ,在 调试 程序 时 浪费 较 多 的 资源 。 同 时 
要 注意 保存 现 有 的 数据 ,以 备 下 次 实验 使 用 。 

(3) 实验 模式 的 探讨 。MySQL 的 上 机 实验 贯穿 整个 数据 库 操作 的 教学 过 程 。 实 验 不 
青 是 单一 的 上 机 调试 程序 ,建议 根据 学 生 的 基础 和 课时 要 求 按 阶段 分 成 两 种 模式 : 上 机 验 
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证 和 自由 上 机 。 

上 机 验证 是 指 学 生根 据 实验 指导 书 的 操作 步骤 进行 操作 ,并 认真 做 好 记录 。 这 种 方式 
一 定 让 学 生 先 做 好 实验 的 预习 ,教师 在 答疑 过 程 中 ,对 于 普遍 存在 的 问题 及 时 进行 总 结 。 

自由 上 机 是 指 当 学 生 掌握 了 调试 程序 的 基本 方法 后 ,可 以 采取 自由 上 机 的 方式 。 目 前 
许多 学 校 提供 电源 和 网 络 环境 ,让 学 生 能 够 利用 自己 的 笔记 本 电脑 进行 自由 上 机 。 这 样 一 
来 ,学 生 就 可 以 自己 安排 时 间 进 行 试验 , 比 利 用 公共 计算 机 省 去 了 环境 配置 和 数据 管理 等 基 
本 操作 的 时 间 , 从 而 进一步 提高 学 生 调试 程序 的 效率 和 能 力 ,增强 学 生 学 习 数 据 库 语言 的 自 
信心 。 

(4) 充分 利用 网 络 资源 。 建 立 班级 或 课程 交流 平台 ,把 各 种 网 络 教学 资源 有 机 地 整合 
到 实验 教学 中 。 对 于 实验 过 程 中 遇 到 的 问题 ,可 以 通过 网 络 搜索 ,集群 策 群 力 来 解决 问题 ， 
改善 学 生 的 学 习习 惯 ,提高 学 生 学 习 的 主动 性 。 

2. 实验 内 容 的 设置 

针对 本 课程 的 实验 内 容 的 不 同 特点 ,可 以 将 实验 分 为 熟悉 环境 阶段 .基本 操作 阶段 和 技 
术 提 高 阶段 共 三 个 阶段 ,其 主要 内 容 和 基本 要 求 如 下 。 

(1) 熟悉 环境 阶段 。 前 期 准备 阶段 的 主要 任务 是 理解 数据 库 、 数 据 模型 和 数据 库 系 统 
的 基本 概念 ; 根据 要 求 自己 设计 出 一 个 结构 合理 的 数据 库 , 并 且 熟 悉 MySQL 集成 环境 的 
使 用 和 数据 库 及 表 的 建立 ,数据 库 完 整 性 设置 等 。 该 阶段 可 以 针对 教材 的 第 1 章 和 第 2 章 
内 容 进行 设置 。 

(2) 基本 操作 阶段 。MySQL 实验 的 第 2 阶段 为 基本 操作 阶段 。 主 要 任务 是 掌握 
MySQL 语言 的 基本 操作 ,包括 SQL 查询 语句 以 及 与 MySQL 语言 相关 的 数据 库 、 表 、 视 图、 
索引 、 存 储 过 程 、 存 储 函 数 .游标 .触发 器 .事务 和 锁 的 基本 操作 ,并 能 够 针对 各 种 数据 库 对 象 
在 实际 中 的 简单 应 用 进行 了 解 。 该 阶段 可 以 针对 教材 的 第 3 一 9 章 内 容 进行 设置 。 

(3) 提高 阶段 。 技 术 提高 阶段 的 实验 ,要 求学 生 在 掌握 课本 内 容 的 基础 上 ,自学 一 些 相 
关 知 识 , 技 术 提 高 阶段 的 主要 任务 是 掌握 数据 库 系 统 的 设计 与 实现 的 知识 内 容 , 将 理论 知识 
与 实际 问题 相 结 合 。 该 阶段 可 以 针对 教材 的 第 10 一 15 章 内 容 进行 设置 。 这 些 内 容 的 相关 
软件 包括 PHP JSP IIS, Apache, tomcat 以 及 集成 开发 环境 IDE 软件 NetBeans 等 ,这些 都 
是 目前 软件 开发 企业 正在 应 用 的 软件 。 熟 悉 这些 软 件 的 环境 和 操作 对 于 学 生 的 将 来 工作 提 
供 了 良好 的 先 机 。 

3. 教学 重点 与 难点 的 处 理 

CD 客户 端 工具 。 学 会 在 DOS 窗口 进行 各 种 MySQL 语句 的 操作 格式 ,过程 和 技巧 ， 
这 是 MySQL 实验 的 最 常用 方式 。 也 要 学 会 一 些 其 他 操作 ,例如 选择 .复制 .粘贴 等 ,以 及 在 
此 操作 环境 下 的 一 些 快 捷 键 的 操作 。 

(2) 数据 库 和 表 。 数 据 库 是 存储 和 管理 MySQL 数据 的 模式 。 要 对 数据 库 引擎 做 一 些 
简单 的 了 解 , 特 别 是 InnoDB 的 特点 。 

(3) MySQL 语言 。MySQL 语言 的 组 成 要 素 多 ,规则 繁杂 ,应 用 广泛 ,非常 容易 出 错 。 
一 些 常用 的 关键 词 常量. 变量、 函数 .运算 符 和 SQL 语句 都 需要 下 一 些 工 夫 去 熟练 掌握 ,就 
像 学 习 化 学 化 工 类 课程 ,化 学 元 素 符号 和 常用 元 素 特性 必须 记 牢 ,学 习 物 理 要 记 住 一 些 常用 
的 公式 和 参数 一 样 ,只 靠 理解 是 远 远 不 够 的 。select 语句 对 初学 者 来 说 是 比较 复杂 的 ,本 课 
程 先 介绍 基本 的 内 容 . 即 分 清楚 select, from, where,order, group by,having, limit 等 子 句 的 


作用 ,再 介绍 复杂 的 多 表 连 接 和 子 查询 操作 ,然后 学 习 与 MySQL 语句 相关 的 内 容 。 

(4) 常用 数据 库 对 象 。 常 用 数据 库 对 象 包括 索引 、 视 图 、 存 储 过 程 、 存 储 函 数 、 触 发 器 、 
事件 .游标 等 。 主 要 是 掌握 格式 定义 、 编 写 程序 和 应 用 过 程 的 操作 。MySQL 中 的 存储 程序 
本 身 能 够 实现 许多 重要 功能 ,同时 也 是 触发 器 .事件 .游标 和 控制 流 语 句 的 应 用 载体 和 中 介 。 

CO 备份 和 恢复 。 计 算 机 用 户 能 够 对 一 些 重要 文件 .资料 定期 进行 备份 是 必要 的 。 通 
过 恢复 启用 原先 的 文件 备份 ,就 可 以 节省 大 量 的 资源 。 

(6) 权限 管理 。 数 据 库 用 户 访问 到 数据 库 中 的 数据 对 象 , 是 根据 管理 员 分 配给 他 的 权 
限 决定 的 。 不 同 的 用 户 具 有 不 同 的 访问 权限 ,常见 的 访问 权限 有 select 查询 权限 .update 更 
新 权限 „insert 录入 权限 和 delete 删除 权限 。 

CD 日 志和 性 能 优化 。MySQL 的 日 志 管理 使 用 方便 ,功能 强大 ,是 管理 MySQL 服务 
器 和 客户 端的 重要 工具 。MySQL 的 性 能 优化 对 于 管理 大 数据 ,特别 是 优化 查询 操作 ,起 到 
了 不 可 替代 的 作用 ,这 也 是 MySQL 的 特色 。 

(8) 可 视 化 工具 的 使 用 。 可 视 化 工具 的 灵活 运用 是 学 习 MySQL 的 基本 操作 的 有 力 补 
充 。 无 论 是 教材 中 介绍 的 MySQL 自 带 的 可 视 化 工具 Workbeach, 还 是 本 书 第 17 章 介绍 的 
Navicat 和 phpMyAdmin 软件 ,都 具有 很 强大 的 功能 。 只 要 熟悉 一 个 可 视 化 软件 就 可 以 从 
不 同 的 视角 对 MySQL 中 的 数据 库 对 象 和 基本 操作 语句 进行 更 深入 的 理解 。 尤 其 是 熟悉 软 
件 中 的 一 些 图 形 向 导 、 查 询 设计 ,工具 栏 、 菜 单 等 操作 ,会 把 使 用 者 学 习 MySQL 的 兴趣 提高 
到 一 个 新 的 高 度 。 在 实验 过 程 中 ,有 许多 可 视 化 操作 和 命令 操作 在 本 质 上 是 相通 的 ,实验 过 
程 中 应 该 多 总 结 和 归纳 。 

实际 操作 和 反复 探索 是 掌握 MySQL 数据 库 管 理 技术 的 必 经 之 路 ,也 是 理解 和 掌握 本 
课程 难点 和 重点 ,提高 自己 创新 能 力 的 重要 途径 。 

4. 上 机 实验 前 的 准备 工作 

在 上 机 实验 前 的 准备 工作 做 得 好 ,可 以 使 得 上 机 实验 得 到 事半功倍 的 效果 。 准 备 工作 
至 少 应 包括 : 

(1) 第 一 次 实验 前 ,教师 需要 向 学 生 说 明 实验 的 整体 要 求 及 实验 的 目标 任务 。 说 明 实 
验 安排 和 进度 、 实 验 守 则 及 实验 室 安 全 制度 。 

(2) 开始 做 实验 就 要 介绍 上 机 操作 的 基本 步骤 ,注意 了 解 MySQL. 实验 过 程 中 常见 的 
错误 ,要 学 会 使 用 网 络 搜索 功能 。 

(3) MySQL 是 理论 与 实验 相 结合 的 课程 。 上 机 前 应 当先 了 解 相关 的 理论 知识 ,再 预习 
实验 内 容 方法 和 步骤 ,避免 出 现 边 操作 边 熟悉 实验 内 容 的 现象 。 

(4) 该 课程 实验 是 连续 的 整体 ,需要 有 延续 性 。 机 房 应 有 安全 措施 或 学 生 自 己 配备 一 
些 常 用 的 存储 设备 。 避 免 前 面 的 实验 数据 ,程序 被 清除 改动 影响 后 面 的 实验 操作 效率 。 

CO 课 下 多 做 操作 练习 ,如 果 能 结合 实际 课题 进行 训练 ,会 达到 更 好 的 效果 。 

教师 可 以 在 本 实验 内 容 完 成 的 基础 上 ,再 根据 学 生 的 掌握 情况 和 上 机 时 间 的 长 短 指定 
课 后 习题 或 作业 题 作 为 实验 内 容 。 

本 书 给 出 16 个 实验 内 容 ,每 一 次 实验 包括 4 个 以 上 的 操作 模块 ,上 机 时 间 每 次 为 2 小 
时 左右 。 实 验 中 用 到 的 数据 ,基本 上 都 是 采用 teaching 数据 库 中 的 相关 数据 。 

5. 学 生 在 实验 过 程 中 应 达到 的 基本 要 求 

一 个 完整 的 MySQL 实验 的 完成 ,除了 在 掌握 必要 的 理论 的 基础 上 进行 认真 的 操作 以 
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外 ,还 要 记录 好 必要 的 实验 结果 , 养 成 良好 的 实验 习惯 ,进而 完成 实验 报告 。 

(1) 实验 之 前 对 本 实验 对 应 的 理论 内 容 进 行 预习 。 

(2) 实验 过 程 中 要 遵守 实验 室 纪律 ,不 做 与 本 实验 无 关 的 事情 。 

(3) 实验 过 程 中 应 及 时 发 现 问 题 并 解决 。 

(4) 实验 报告 要 求 认真 按 规定 格式 书写 ,实验 报告 要 求 独 立 完 成 并 按时 上 交 。 

学 习 计 算 机 语言 应 该 清楚 一 个 这 样 的 事实 : 教材 不 可 能 将 软件 的 内 容 完 全 介绍 ,教师 
上 课 也 不 可 能 将 所 有 的 操作 全 部 演示 。MySQL 中 的 每 一 个 数据 库 对 象 , 都 可 以 通过 命令 
实行 若干 操作 ,也 可 以 利用 可 视 化 操作 形式 实现 。 只 要 在 掌握 命令 格式 和 功能 的 基础 上 ,做 
一 些 验证 实验 ,总 结 出 该 操作 的 主要 内 涵 即 可 。 

6. 实验 报告 的 撰写 

根据 实验 内 容 的 记录 整理 出 实验 报告 是 实验 过 程 中 的 一 个 重要 组 成 部 分 。 实 验 报告 的 
格式 要 求 规 范 简洁. 言 之 有 物 , 以 此 达到 锻炼 学 生 的 文字 表达 能 力 、 提 出 和 发 现 问题 的 能 
力 、. 归 纳 和 总 结 的 能 力 的 目的 。 撰 写实 验 报告 ,切忌 养 成 不 加 思考 随意 抄袭 、 拼 凑 一 些 可 有 
可 无 的 内 容 、 编 造 实验 结果 记录 等 坏 习惯 。 

实验 报告 一 般 应 包括 以 下 内 容 : 

COD 实验 项 目 。 如 : 实验 1 认识 MySQL 的 运行 环境 。 

(2) 实验 目的 。 简 述 本 次 实验 应 该 达到 的 目标 。 

(3) 实验 内 容 。 操 作 步 又 、 命 令 或 程序 清单 .中 间 结 果 等 。 

(4) 运行 结果 。 

(5) 总 结 本 次 实验 过 程 中 所 取得 的 经 验 ,分 析 实 验 过 程 中 的 出 错 原 因 并 提出 可 能 的 解 
决 方法 。 


18.2 MySQL 5.7 实验 内 容 


实验 1 MySQL 5.7 的 运行 环境 


1. 实验 目的 

A) 熟悉 MySQL 5.7 的 服务 管理 操作 。 

(2) 掌握 MySQL 5.7 的 登录 和 退出 操作 。 

(3) 掌握 常用 系统 函数 、 运 算 符 和 表达 式 的 功能 和 应 用 。 

2. 实验 预习 与 准备 

预习 主教 材 第 1 章 和 第 2 36. 

(D MySQL 5. 7 环境 的 常用 工具 。 

(2) 利用 select 语句 进行 输出 的 操作 。 

(3) MySQL 的 服务 器 管理 。 

3. SEXUS TESCO 

OD MySQL 的 启动 和 退出 。 

(OD 执行 cmd 命令 启动 。 执 行 “ 开 始 ” 一 “运行 ”命令 ,打开 DOS 窗口 ,在 DOS 提示 符 下 
输入 登录 命令 后 ,按照 指示 位 置 输入 密码 ,登录 成 功 的 结果 如 下 : 


C:\Users\Administrator > mysql — u root -p 

Enter password: ****** 

mysql> 

© MySQL 客户 端 登录 数据 库 。 在 Windows 7 操作 系统 中 ,执行 “开始 ”一 “所 有 程 
序 ” 一 MySQL MySQL 5.7 命令 ,该 目录 下 包含 MySQL Command Line Client 和 
MySQL Command Line Client-Unicode 两 个 选项 。 它 们 都 是 MySQL 客户 端的 命令 行 工 
具 。 执 行 该 命令 后 ,按照 提示 位 置 输入 密码 , 即 可 执行 相关 MySQL 命令 。 

@ 退出 。 在 “mysql >” 提 示 符 下 ,输入 quit 或 exit 命令 ,都 可 以 退出 MySQL 登录 。 

(2) MySQL 服务 的 启动 和 退出 。 

D 执行 “开始 ”一 运行 ”命令 并 输入 services. msc JA fk Enter 键 也 可 以 弹出 图 18-1 所 
示 的 窗口 。 右 击 MySQL 57 服务 ,可 以 在 弹出 的 菜单 中 执行 “启动 “停止 “暂停 ”? 和 “恢复 ” 
等 命令 。 

© 执行 “开始 ”一 “设置” 一 “控制 面板 ”>“ 管 理工 具 ” 一 “服务 ”命令 进行 设置 ,打开 的 窗 
口 如 图 18-1 所 示 。 右 击 MySQL 57 服务 ,可 以 在 弹出 的 菜单 中 执行 “启动 “停止 “暂停 ?和 
“恢复 ”等 命令 。 

© 执行 cmd 命令 启动 服务 。 在 DOS 窗口 中 ,net start mysql57 表示 启动 MySQL Jl 
务 ,net stop mysql57 表示 关闭 MySQL 服务 。 

© 选中 图 18-1 的 MySQL57 服务 项 右 击 ,在 弹出 的 快捷 菜单 中 选择 “属性 ”命令 ,弹出 
如 图 18-2 所 示 的 对 话 框 。 
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18-31 “服务 ”窗口 
(3) 常量 和 变量 的 应 用 。 
O 查看 字符 “c” 开 头 的 系统 变量 命令 。 
mysql > show variables like 'c%'; 
© 查看 当前 MySQL 软件 的 版 本 号 和 当前 时 间 。 


mysql» select @ @version, current_date; 
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显示 名 称 MySQLST 
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可 执行 文件 的 路 径 
"C:\Program 了 ilesVWiySQLWIySQL Server 5.7\bin\nysqld exe" 一 





当 从 此 处 启动 服务 时 ， 您 可 指定 所 适用 的 启动 参数 。 


gps qn 














图 18-2 更改 服务 的 启动 类 型 
@ 针对 当前 会 话 ,把 系统 变量 sql select limit 的 值 设 置 为 100。 


mysql» set (Q(Qsession.sql select limit = 100; 
(4) 运算 符 的 应 用 。 

Q 算术 运算 符 : 

mysql» select 5+2.7,1.5* 3,3/5,10- 27.5,5 $3; 


@ 比较 运算 符 : 


mysql» select 'T'>'B',1 +3=2, 'X'<'x', 8<>8，'a'<= 'u'; 
mysql> select null is null,1.3 is null, 11.9 is not null; 
mysql» select  'MySQL'like 'MY % ', 'APPLE'like 'AB ' 


O Eis SERE: 


mysql» select ('T'- 'B'),('c' = 'C')and('c'«'D')or(7 7 8); 
mysql» select ('A'= 'a') $& (12 2), ('F' 7 '£') xor (15172); 


@ 位 运算 符 : 


mysql» select 5&1,7 [3,100022 5, —9,6^7; 
mysql» select 5&5,7|9,10««2, —0,6^0; 


(5) 系统 函数 的 应 用 。 
( 数学 函数 : 


mysql» select cos(3.67),tan(4.71), sin(5),PI(); 
mysql> select 6+ round(10 * rand(),0) , 20+ round(10 * rand(),0); 


© 时 间 日 期 函数 : 


mysql» select dayofyear(20180515), dayofmonth('2018 - 05 - 15"); 


mysql > select dayofmonth( '2018 - 07 - 15") , dayofweek(now()) ; 
mysql > select hour(curtime()), minute(curtime()), second(curtime()); 
mysql» select date sub('2018— 10— 1 10:10:10', interval 27 minute); 


© 字符 串 函 数 : 


mysql> select concat( 'you', ' are', ' best'), concat( '123', '456', null); 
mysql» select right( 'ABCDEFGH', 5) , reverse(left( 'ABCDEFGH', 5) ); 
mysql» select length('12345abcde'),char length('123 数据 库 技术 cde'); 


(D 其 他 函数 : 


mysql» select version(),database(),user(), CONNECTION ID(); 
mysql > select password( 'teach1727'); 

mysql> select format(7/3,3), format(123456.78,1); 

4. 实验 报告 总 结 

CD select 语句 的 输出 功能 。 

(2) 常规 标识 符 的 命名 规则 。 

(3) 常用 运算 符 的 使 用 方法 及 其 优先 级 。 

(4) 常用 系统 函数 的 功能 和 调用 方法 。 


实验 2 数据 库 的 基本 操作 


1. 实验 目的 

CD 掌握 数据 库 的 存储 方式 。 

(2) 掌握 创建 、 修 改 数据 库 的 方法 。 

(3) 掌握 管理 数据 库 的 方法 。 

2. 实验 预习 与 准备 

预习 主教 材 第 3 W: 

(1) 数据 库 的 基本 概念 和 存储 方式 。 

(2) 利用 MySQL 语句 创建 和 管理 数据 库 。 
G) 利用 MySQL 可 视 化 工具 管理 数据 库 。 
3. 实验 内 容 及 步骤 

(1) 查看 数据 库 。 

© ÆA MySQL 数据 库 的 存储 位 置 。 
参考 安装 路 径 : F:NDocuments and Settings\All Users\MySQL\MySQL Server 5. 7\Data。 
© 查看 当前 系统 中 的 数据 库 : 


mysql > show databases; 
© 查看 系统 中 的 数据 库 引 擎 : 
mysql > show engines; 

CD 设置 InnoDB 为 当前 数据 库 引擎 


mysql» set default storage engine = InnoDB; 
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(2) 数据 库 的 基本 操作 。 
(D 创建 infol 数据 库 和 info2 数据 库 : 
mysql > create database infol 

一 > default character set gb2312 


一 > default collate gb2312 chinese ci; 
mysql > create database if not exists info2; 


@ 练习 从 当前 安装 路 径 查看 已 经 存在 的 数据 库 。 
© 打开 数据 库 infol: 


mysql > use infol; 
@ 修改 数据 库 info2: 


mysql > alter database info2 
一 > default character set gb2312 
一 > collate gb2312 chinese ci; 


© 显示 数据 库 infol 的 结构 信息 : 
mysql > show create database infol; 
© 删除 数据 库 info2: 

mysql > drop database info2; 


(3) 利用 MySQL Workbench 创建 和 管理 数据 库 。 

(D 从 “开始 ”>“ 所 有 程序 ”中 找到 MySQL 文件 夹 ,执行 MySQL Workbench 命令 , 进 
A MySQL Workbench 主 界面 ,连接 MySQL 57。 进 入 MySQL Workbench 数据 库 操作 的 
主 界面 ,如 图 18-3 所 示 。 


| File Ms Vier deny Deae Sarver Tels Seriptine Ma 
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d Data Export 
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Q oanboard 
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18-3 ”数据库 操 作 主 界面 





UE 











@ 创建 数据 库 teaching. 

© 设置 数据 库 teaching 的 字符 集 和 排序 规则 参数 ,也 可 以 使 用 默认 值 。 

CD 查看 数据 库 。 在 数据 库 操作 界面 的 schemas 区 域 ,就 可 以 看 到 刚才 创建 的 数据 库 
teaching 是 否 存 在 。 

© 删除 数据 库 infol. 

© 设置 数据 库 teaching 为 当前 数据 库 , 如 图 18-4 所 示 。 

4. 实验 报告 总 结 

(1) 创建 数据 库 的 默认 路 径 和 字符 集 设置 。 

(2) 常用 系统 数据 库 的 功能 。 

(3) 数据 引擎 的 作用 。 


实验 3 数据 表 的 基本 操作 


1. 实验 目的 

CD 掌握 创建 和 修改 表 结 构 的 方法 。 

(2) 掌握 插入 表 数 据 的 方法 。 

G) 掌握 更 新 表 数 据 的 方法 。 

(4) 掌握 删除 表 数 据 的 方法 。 

2. 实验 预习 与 准备 

预习 主教 材 第 2. 2 节 和 第 4. 1 一 4. 3 节 : 

(1) MySQL 的 系统 数据 类 型 。 

(2) 表 结 构 的 创建 ,修改 和 删除 。 

(3) 表 数 据 的 浏览 .插入 、 更 新 和 删除 。 

3. 实验 内 容 及 步 又 

CD 创建 表 结构 。 如 表 18-1 所 示 , 这 是 教材 中 的 一 个 student 表 的 结构 的 字段 列表 。 
根据 该 表 的 内 容 ,学 会 利用 SQL 语句 创建 表 结构 。 


表 18-1 student 表 结 构 


SCHEMAS er 
Q Fiter objects 


P E mysqltest 
bo sakila 








图 18-4 查看 数据 库 























列 序号 字段 名 类 型 取 值 说 明 列 含义 
1 studentno Char(11) 主键 学 生 学 号 
2 sname Char(8) 否 学 生 姓 名 
3 sex enum (2) 否 性 别 
4 birthdate Date 否 出 生日 期 
5 entrance int(3) 否 入 学 成 绩 
6 phone varchar(12) 否 电话 
7 Email varchar(20) 否 电子 信箱 














(D 登录 MySQL 后 ,打开 数据 库 teaching, 输 入 下 列 代码 即 可 创建 student 表 结 构 : 


mysql» create table if not exists student 


( 第 
studentno char(11) not null, 2 
sname char(8) not null, Sp 

分 
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sex enun( ' 男 '，' 女 ') default ' 男 '， 
birthdate date not null, 

entrance int(3) null, 

phone varchar(12) not null, 
Email varchar(20) not null , 
primary key (studentno) 

E 


@ 查看 表 和 表 结 构 ; 


mysql» show tables; 
mysql» describe student; 


© 创建 course 表 结 构 。 程 序 代 码 如 下 : 


mysql > create table if not exists course 
( 
courseno char(6) not null, 
cname char(6) not null, 
type char(8) not null, 
period int(2) not null, 
exp int(2) not null, 
term int(2) not null, 
primary key (courseno) 


) 
CD 创建 score 表 结 构 。 程 序 代码 如 下 : 


mysql > create table if not exists score 
(studentno char(11) not null, 
courseno char(6) not null, 
daily float(3,1) default 0, 
final float(3,1) default 0, 
primary key (studentno , courseno) 


); 
C) 创建 teacher 表 结 构 。 程 序 代 码 如 下 : 


mysql > create table if not exists teacher 
(teacherno char(6) not null comment ' 教 师 编 号 '， 
tname char(8) not null comment' 教 师 姓名 '， 
major char(10) not null comment ' 专 业 '…， 
prof char(10) not null comment ' 职 称 '， 
department char(16) not null comment ' 部 门 ', 
primary key (teacherno) 


); 
© 创建 teach course 表 结 构 。 程 序 代码 如 下 : 


mysql» create table if not exists teach course 
(teacherno char(6) not null, 
courseno char(6) not null, 
primary key (teacherno, courseno) 


) 


(D 创建 选课 表 sc。 程 序 代码 如 下 : 


mysql > create table sc 
(sc no int(6) not null auto_increment, 
studentno char(11) not null, 
courseno char(6) not null, 
teacherno char(6) not null, 
Sc time timestamp not null default now(), 
primary key (sc no) 


) 





创建 完毕 ,可 以 通过 安装 路 径 ( 如 : F:\Documents [Sam 





and Settings\ All Users \ MySQL M MySQL Server 5.7\ |? Fher jects 
DataNteaching) 查 看 磁盘 文件 数据 库 及 其 包含 的 数据 表 
文件 。 

(2) 在 可 视 化 工具 MySQL Workbench 中 修改 表 结 
构 。 在 可 视 化 工具 MySQL Workbench 中 展开 数据 库 
teaching 下 的 表 , 右 击 其 中 一 个 表 , 如 course 表 , 如 图 18-5 
所 示 ,可 以 通过 执行 菜单 命令 Alter Table 实现 对 表 结 构 
的 修改 。 其 他 表 的 表 结 构 也 可 以 通过 这 种 方式 修改 ,也 可 
以 参考 教材 的 相关 内 容 , 利 用 命令 方式 修改 表 结 构 。 

(D 选择 course 表 执 行 菜单 命令 Alter Table. 如 
图 18-6 所 示 。 
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图 18-6 修改 表 结 构 


@ 在 此 可 以 修改 表 名 、 默 认 字符 集 序 列 和 数据 库 引擎 等 表 属 性 。 
@ 可 以 修改 字段 名 ,字段 类 型 .字段 长 度 等 字段 属性 。 
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@ 可 以 利用 弹出 菜单 移动 字段 顺序 ,复制 . 剪 切 和 粘贴 字段 ,也 可 以 删除 .增加 和 修改 
字段 ,清除 默认 值 等 。 

© 还 可 以 修改 约束 条 件 、 默 认 值 和 字段 的 自动 增长 等 字段 属性 。 

© 修改 完毕 , 单 击 Apply 按钮 ,就 可 以 保存 表 结构 的 修改 内 容 。 

(3) 录入 表 数 据 。 数 据 库 teaching 的 常用 表 的 比较 完整 的 数据 可 以 参考 本 书 第 4 章 的 
数据 表 数 据 附录 的 内 容 。 也 可 以 参考 教材 的 例 4. 12 一 例 4. 18 的 内 容 。 

CD 利用 insert 向 表 student 中 插入 1 行 数据 : 


mysql > insert into student 
— »(studentno, sname, sex, birthdate, entrance, phone, Email) 
-> values ('18122210009', ' 许 东山 ', 38 ', 1999/11/5',789, 
-> 13623456778', 'qwe@163. con') ; 


© 利用 insert into 命令 向 表 student 中 插入 多 行 数据 : 


mysql > insert into student values 
-> ('18122221324', ' 何 白露 '， 
一 > ' 女 ', 2000/12/4', '879', '13178978999', 'heyy(2 sina. com '), 
一 > ('18125111109', ' 散 横江 '， 
-> ' 男 ', '2000/3/1', '789',' 15678945623', 'jing@sina. com '), 
-> ('18125121107', ' 梁 一 苇 '， 
一 > ' 女 ', '1999/9/3','777',' 13145678921', 'bing(2126.com '); 


© 利用 replace into 命令 向 表 course 中 插入 多 行 数据 : 


mysql > replace into course values 
-> ('c05103', ' 电 子 技术 ', ' 必 修 ', 647, '16', '2')， 
-> ('c05109', 'C 语 言 ', ' 必 修 ', '48', '16', '2')， 
-> ('c05127', ' 数 据 结 构 ', ME, '64', '16', '2'); 
CD 可 以 利用 load data 请 句 将 数据 装 入 数据 库 表 中 ,实际 上 这 是 将 其 他 类 型 数据 导入 
到 数据 表 的 操作 。 假 设 teacher 表 的 数据 已 放 在 “d:\teacher. txt” 中 ,就 可 以 执行 如 下 命令 
导入 数据 。 注 意 导入 文件 路 径 采 用 “\\ ”方式 , 即 转 义 字符 方式 。 


mysql> load data local infile "d:\\teacher. txt" into table teacher; 
© 利用 set 子 句 向 score 表 插入 数据 : 


mysql > insert into score 
—» set studentno = '19120000111', 
一 > courseno = 'c05109', daily = 90, final = 95; 


© 利用 现 有 的 表 创建 和 复制 成 新 表 , 新 表 中 含有 全 部 或 部 分 字段 和 数据 : 
mysql» create table stud as select * from student; 


C 利用 可 视 化 工具 MySQL Workbench 添加 数据 。 选 择 要 添加 数据 的 表 student. 在 
图 18-5 所 示 的 菜单 中 ,执行 Select Rows 命令 ,如 图 18-7 所 示 , 即 可 在 表 中 添加 数据 。 添 加 
完毕 , 单 击 Apply 按钮 ,保存 即 可 。 如 果 放 弃 添 加 , 单 击 Revert 按钮 即 可 。 
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图 18-7 添加 表 数 据 


(4) 修改 表 数 据 。 
(D 修改 指定 记录 的 数据 : 


mysql > update score set daily= 95 
-> where studentno = '18137221508' && courseno = 'c08126'; 


© 成 批 修改 记录 : 
mysql > update stud set entrance = entrance * 1. 08 where entrance< 600; 


@ 利用 可 视 化 工具 MySQL. Workbench 修改 数据 。 选 择 要 修改 数据 的 表 teacher, TA 
f Select Rows 命令 ,如 图 18-8 所 示 , 即 可 在 表 中 修改 数据 ,如 修改 字段 值 * 计 算 机 应 用 ”为 
“计算 机 技术 ”。 修 改 完毕 ,关闭 窗口 ,在 新 对 话 框 中 单 击 Apply 按钮 ,保存 即 可 。 如 果 放 弃 
添加 , 单 击 Revert 按钮 即 可 。 

(5) 删除 表 数 据 。 

CD 删除 符合 条 件 的 指定 记录 行 。 删 除 student 表 中 入 学 成 绩 低 于 600 分 的 记录 : 


mysql» delete from student where entrance < 600; 
© 利用 limit 子 句 删除 指定 记录 行 。 删 除 student 表 中 入 学 成 绩 最 低 的 2 行 记录 : 
mysql? delete from student order by entrance limit 2; 


© 利用 可 视 化 工具 MySQL. Workbench 删除 数据 。 在 如 图 18-9 所 示 的 菜单 中 ,执行 
Delete Rows 命令 , 即 可 删除 指定 记录 行 。 

CD 清空 表 记 录 , 即 一 次 性 删除 表 中 的 所 有 记录 。 如 图 18-10 所 示 ,执行 Truncate Table 
命令 , 即 可 删除 选 定 的 所 有 记录 。 
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18-9 删除 表 数 据 




















» B del Select Rows - Limit 10 
pE mm sane Inspector 





» E soi 

» E soi Copy to Clipboard , 

pE s! saa to SOL Editor » 

>E stu 

>E stu) Creste Table.. 

pE stud — cate Table Like.. » 

» Bl stud 

bE tea Alter Table... 

p E teac Table Maintenance... | 
> Views 
b P Storedi Drop Table... | 
 ByFundio| Truncate Table... | -| 


Search Table Data 





图 18-10 清空 表 数据 


当然 ,在 DOS 窗口 中 执行 如 下 命令 也 可 以 删除 指定 表 stud 的 所 有 数据 。 


mysql» truncate table stud; 


4. 实验 报告 总 结 

CD 创建 表 结 构 的 方法 总 结 。 

(2) 修改 表 结 构 对 表 中 记录 的 影响 。 

(3) 利用 可 视 化 工具 MySQL Workbench 管理 表 的 优势 。 


实验 4 数据 完整 性 的 基本 操作 


1. 实验 目的 

(1) 理解 实现 数据 完整 性 的 概念 。 

(2) 掌握 创建 、 修 改 主键 约束 的 方法 。 
(3) 掌握 利用 MySQL 语句 创建 其 他 约束 的 方法 。 
2. 实验 预习 与 准备 

预习 主教 材 第 4.4 节 : 

(1) 数据 完整 性 的 类 型 和 实现 机 制 。 
(2) 5 类 约束 的 创建 和 修改 。 

3. 实验 内 容 及 步 又 

CD 主键 约束 的 创建 与 应 用 。 

CD 利用 course 表 创建 一 个 新 表 coursel : 


mysql» create table coursel as select * from course; 


@ 创建 course01 的 主键 约束 ,字段 名 为 cname: 


mysql > alter table coursel add primary key (cname); 


© 删除 主键 约束 ,重新 创建 主键 约束 ,字段 名 为 courseno: 


mysql > alter table coursel drop primary key; 
mysql > alter table coursel add primary key (courseno); 


CD. 验证 主键 约束 ,观察 主键 值 重 复 时 的 数据 插入 情况 : 
mysql > insert into coursel values 
-> ('c05188', ' 电 子 技术 ', ME, 647, '16', '2'); 
mysql > insert into coursel values 
-> ('c05188', ' 控 制 原理 ', MAE", '64', 207,37); 
(2) 外 键 约束 的 创建 和 应 用 。 
CD 利用 score 表 创建 一 个 新 表 scorel : 


mysql» create table scorel as select * from score; 
@ 对 表 score01 添加 外 键 : 


mysql > alter table scorel 
一 > add constraint fk cou score 
一 > foreign key(courseno) references coursel(courseno); 
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© 验证 外 键 约束 ,观察 外 键 值 对 数据 插入 情况 的 影响 : 


mysql > insert into scorel values 
-> ('18137221508', 'c05109',94,92); 
mysql» insert into scorel values 
-> ('18137221508', 'c11111', 99,98); //coursel 表 中 无 'c11111 "课程 号 


(3) 检查 约束 的 创建 和 应 用 。 
(D 创建 检查 约束 ,final 值 以 0— 100 为 界 值 : 


mysql > alter table scorel 
-> add constraint sc_checkl check(final = 0 and final <= 100); 


@ 验证 检查 约束 ,观察 合法 与 非法 数据 插入 的 情况 : 


mysql > insert into scorel values 
-> ('19126113307', 'c05109',94, 100); 
mysql» insert into scorel values 
一 > ('19122203567','c05108',94,101); //final 值 超 界 
(4) 唯一 约束 的 创建 和 应 用 。 
(D 创建 唯一 约束 : 


mysql» alter table student add unique(phone); 
@ 验证 唯一 约束 ,观察 重复 电话 数据 插入 的 情况 : 


mysql» select studentno, sname, phone from student; 
mysql» insert into student values 
-> (19126113306', ' 梅 青 ', ' 女 ', '2001/9/7', 787," 
-> 13245678543', 'nei(2163. con') ; 


(5) 非 空 约束 的 应 用 。 主 键 字段 值 不 允许 为 null, 输 入 空 值 观察 结果 : 
mysql > insert into coursel values 
-> (null, ' 网 络 技术 ', ' 必 修 ', 647, '16', '2'); 

(6) 利用 可 视 化 工具 MySQL. Workbench 管理 表 的 约束 。 在 MySQL Workbench 窗口 
中 修改 scorel ,如 图 18-11 所 示 。 可 以 通过 表 结 构 中 字段 后 面 的 复 选 按钮 管理 主键 约束 、 唯 
一 约束 和 非 空 约束 。 如 果 单 击 图 形 下 方 的 foreign keys 标签 ,还 可 以 管理 外 键 约束 。 

4. 实验 报告 总 结 

CD 不 同类 型 数据 完整 性 的 特点 和 实现 方法 。 

(2) 各 种 约束 的 功能 及 对 表 数 据 修改 的 影响 。 


实验 5 MySQL 数据 的 查询 基本 操作 


1. 实验 目的 

A) 掌握 select 语句 的 格式 和 各 子 句 的 功能 。 

(2) 掌握 where 子 句 中 like\in、between...and'\is 等 逻辑 运算 符 的 使 用 。 
(3) 掌握 group by 语句 和 聚合 函数 的 使 用 。 
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18-11 完整 性 约束 


2. 实验 预习 与 准备 
预习 主教 材 第 5. 1 一 5. 3 W: 
CD 利用 select... from 子 句 实现 投影 查询 和 设置 结果 集 格式 。 
(2) 利用 where 子 句 实现 数据 过 滤 。 
(3) 利用 group by 子 句 和 having 子 句 实现 分 组 查询 。 
(4) group by 语句 和 聚合 函数 的 使 用 。 
(5) 利用 limit 子 句 输出 部 分 记录 。 
3. 实验 内 容 及 步 又 
CD select... from... where 基本 子 句 的 使 用 。 
(D 在 student 表 中 查询 出 生日 期 在 2003 年 以 前 的 学 生 的 学 号 、 姓 名、 电话 和 年 龄 : 
mysql» select studentno 学 号 , sname 姓名 ， 
-> phone 电话 , year(now()) - year(birthdate) 年 龄 


->from student 
一 > where birthdate <'2003 - 01 - 01'; 


@ 在 score 表 中 查询 期 中 成 绩 高 于 90 分 的 学 生 的 学 号 和 课程 号 ,并 按照 学 号 排序 : 


mysql» select distinct studentno, courseno 
->from score 
一 > where daily > 90 
一 > order by studentno; 


© 查询 学 号 分 别 为 18122221324,18137221508 和 18137221508 学 生 的 课程 号 .平时 成 
绩 和 期 末 成 绩 : 


mysql > select studentno, courseno , daily , final 
一 > from score 
一 > where studentno in('18122221324', '18137221508', 18137221508"); 


Yny 
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CD 查询 选修 课程 号 为 c08123 的 学 生 的 学 号 和 期 末 成 绩 ,并 且 要 求 平 时 成 绩 在 85 — 
100 分 。 


mysql» select studentno, final 
一 > from score 
一 > where courseno = 'c08123' and daily between 85 and 100; 


© 在 student 表 中 显示 所 有 姓 赵 的 学 生 的 姓名 、 生 日 和 Email: 


mysgl» select sname, birthdate, Email 
一 > from student 
一 > where sname like ' 赵 $ '; 


© 在 score 表 中 显示 期 中 成 绩 高 于 85 分 、 期 末 成 绩 高 于 90 分 的 学 生 的 学 号 .课程 号 和 
成 绩 : 
mysql > select studentno, courseno, daily, final 


一 > from score 
-> where daily >= 85 and final >= 90; 


CD 查询 计算 机 学 院 专业 为 “软件 工程 ”或 “网 络 技术 ”的 教师 的 教师 号 、 姓 名 和 职称 : 


mysql > select teacherno, tname, prof 
一 > from teacher 
一 > where department = ' 计 算 机 学 院 ' 
-> and (major = ' 软 件 工程 'or major = ' 网 络 技术 '); 
(2) 排序 分 组 和 限定 记录 的 查询 。 
O 在 student 表 中 输出 高 于 800 分 的 学 生 的 学 号 ,姓名 、 电 话 和 入 学 成 绩 , 并 按照 入 学 
成 绩 的 降序 排列 : 


mysql > select studentno , sname , phone, entrance 
一 > from student 
一 > where entrance > 800 
一 > order by entrance desc; 


© 在 score 表 中 查询 总 评 成 绩 大 于 85 分 的 学 生 的 学 号 .课程 号 .电话 和 总 评 成 绩 ,并 先 
按照 课程 号 的 升序 .再 按照 总 评 成 绩 的 降序 排列 。 总 评 成 绩 计 算 公 式 如 下 : 
总 评 成 绩 一 daily* 0. 2+ final * 0. 8 
mysql» select courseno,daily * 0.2+ final* 0.8 as ' 总 评 ', phone, studentno 
一 > from score 


-> where daily * 0.2 * final* 0.8» 85 
一 > order by courseno, daily * 0.2 * final * 0.8 desc; 


© 利用 group by 子 句 对 score 表 数 据 分 组 ,显示 每 个 学 生 的 学 号 和 平均 总 评 成 绩 。 总 
评 成 绩 计算 公式 如 下 : 

总 评 成 绩 = daily * 0. 3 十 finalx 0. 7 

mysql» select studentno , round(avg(daily * 0.3 * final * 0.7),2) as avgl 


一 > from score 
一 > group by studentno; 


CD 使 用 group by 关键 字 和 group. concat O 函数 对 score 表 中 的 courseno 字段 进行 分 
组 查询 。 可 以 查看 该 学 生 选 修 的 课程 号 : 


mysql > select studentno 学 号 , group_concat(courseno) 选课 学 生 
一 > from score 
一 > group by studentno ; 


C) 查询 选课 在 2 门 以 上 且 各 门 课程 期 末 成 绩 均 高 于 85 分 的 学 生 的 学 号 及 其 总 成 绩 ， 
查询 结果 按 总 成 绩 降序 列 出 : 


mysql» select studentno 学 号 ,sum(dailyx 0.3 + final* 0.7) as ' 总 分 ' 
->from score 
一 > where final» - 85 
一 > group by studentno 
一 > having count( * )» - 2 
-> order by sun(daily * 0.3 + final * 0.7) desc; 


© 查询 score 表 中 期 末 成 绩 final 高 于 90 分 的 成 绩 ,按照 平时 成 绩 daily 进行 升序 排 
列 , 从 编号 1 开始 ,查询 3 条 记录 : 
mysql? select * from score 
-» where final»90 
-» order by daily asc 
=> liait 1,3; 
(3) 聚合 函数 的 应 用 。 
O 查询 score 表 中 学 生 的 期 末 总 成 绩 大 于 275 分 的 学 生 学 号 、 总 成 绩 及 平均 成 绩 : 
mysql» select studentno 学 号 ，sum(final) 总 分 avg(final) 平 均 分 
一 > from score 
一 > group by studentno 


-> having sum(final)» 275 
-> order by studentno; 


@ 查询 选修 课程 号 为 c05103 的 学 生 的 期 末 最 高 分 .最 低 分 及 之 间 相 差 的 分 数 ; 


mysql» select max(final) 最 高 分 , min(final) 最 低 分 ， 
-> max(final) - min(final) as 分 差 
一 > from score 
一 > where (courseno = 'c05103'); 


© 查询 score 表 中 每 个 学 生 的 期 末 平 均值 和 所 有 成 绩 的 平均 值 : 


mysql > select studentno 学 号 ,avg(final) 平均 分 
一 > from score 
一 > group by studentno with rollup; 


4. 实验 报告 总 结 

CD 逻辑 运算 符 在 where 子 句 中 的 使 用 方法 。 
(2) 利用 带 有 通配符 的 like 实现 模糊 查询 的 特点 。 
(3) group by 子 句 在 数据 统计 中 的 应 用 。 
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实验 6 多 表 连 接 和 子 查 询 


1. 实验 目的 

(1) 掌握 多 表 连 接 查询 . 子 查询 的 基本 概念 。 

(2) 掌握 多 表 连 接 的 各 种 方法 ,包括 内 连接 .外 连接 .交叉 连接 等 。 
(3) 掌握 子 查询 的 方法 ,包括 相关 子 查询 和 不 相关 子 查询 。 

(4) 掌握 正则 表达 式 在 查询 中 的 作用 。 

2. 实验 预习 与 准备 

预习 主教 材 第 5. 5 和 第 5.65. 

(1) 利用 多 表 连 接 方式 查询 数据 的 3 种 基本 格式 。 

(2) 利用 子 查询 方式 查询 数据 。 

(3) 利用 正则 表达 式 进行 模糊 查询 的 基本 过 程 。 

3. 实验 内 容 及 步 又 

CD 查询 选修 课程 号 为 c06108 的 学 生 的 学 号 、 姓 名 和 期 末 成 绩 : 


mysql > select student. studentno, sname, final 
一 > from student inner join score 
-> on student. studentno = score. studentno 
-> where score. courseno = 'c06108'; 


(2) 利用 左 外 连接 方式 查询 学 生 的 学 号 .姓名 ,平时 成 绩 和 期 末 成 绩 : 


mysql» select student. studentno, sname, daily, final 
-» from student left join score 
一 > on student. studentno = score. studentno; 


(3) 利用 右 外 连接 方式 查询 教师 的 排 课 情况 : 


mysql»? select teacher. teacherno, tname, major, courseno 
-» from teacher right join teach course 
一 > on teacher.teacherno = teach course. teacherno; 


(4) 查询 19 级 学 生 的 学 号 、 姓 名 、 课 程 名 、 期 末 成 绩 及 学 分 : 


mysql» select student. studentno, sname, cname, final, round(period/16,1) 
一 > from score join student on student. studentno = score. studentno 
-> join course on score. courseno = course. courseno 
一 > where left(student. studentno,2) = '19'; 


C5) 查询 期 末 成 绩 高 于 90 分 ,总评 成 绩 高 于 85 分 的 学 生 的 学 号 .课程 号 和 总 评 成 绩 ， 


mysql» select TT. studentno 学 号 ,TT. courseno 课程 号 , 
-> TT. final * 0.8 + TT.daily* 0.2 总 评 
—» from (select * from score where final>90) as TT 
—> where TT. final * 0.8 + TT. daily * 0.2» 85; 


(6) 查询 期 末 成 绩 比 选修 该 课程 平均 期 末 成 绩 低 的 学 生 的 学 号 .课程 号 和 期 末 成 绩 ， 


mysql > select studentno, courseno, final 


一 > from score as a 
一 > where final < (select avg(final) 


-> from score as b 
一 时 where a. courseno = b. courseno 
-» group by courseno ); 


(7) 获取 期 末 成 绩 中 含有 高 于 90 分 的 学 生 的 学 号 、 姓 名 、 电 话 和 E-mail: 


mysql» select studentno, sname, phone, Email 
-> from student 
一 > where studentno in ( select studentno 
=> from score 


=% where final» 90); 


(8) 查找 score 表 中 所 有 比 c05103 课程 期 末 成 绩 都 高 的 学 号 、 姓 名 .电话 和 期 末 成 绩 ， 


mysql > select student. studentno, sname, phone, final 
一 > from score inner join student 
=S on score. studentno = student. studentno 
-» where final > al1 


-> (select final from score where courseno= 'c05103'); 
(9) 将 student 表 中 1999 年 以 后 出 生 的 学 生 记录 添加 到 stud 表 中 


mysql > insert into stud 
-> ( select * from student 
-> where birthdate >= '1999 - 12- 31"); 


(10) 查询 student 表 中 学 生 电 话 号 码 尾数 为 8 的 学 生 的 部 分 信息 s 


mysql > select studentno, sname, phone, Email 
一 > from student 
一 > where phone regexp '8$ '; 
4. 实验 报告 总 结 
(1) 内 连接 与 外 连接 的 功能 及 区 别 。 
(2) 相关 子 查询 与 不 相关 子 查询 的 功能 及 区 别 。 
(3) 使 用 正则 表达 式 进行 模糊 查询 的 基本 过 程 和 方法 。 


实验 7 索引 和 视图 


1. 实验 目的 

(1) 掌握 索引 和 视图 的 基本 概念 和 功能 。 

(2) 掌握 利用 MySQL 语句 创建 、 维 护 索引 的 方法 。 

(3) 掌握 利用 MySQL 语句 创建 、 修 改 视 图 的 方法 。 

(4) 掌握 通过 视图 插入 、 修 改 、 删 除 基本 表 中 数据 的 方法 。 
2. 实验 预习 与 准备 

预习 主教 材 第 6 章 : 

CD 利用 MySQL 语句 创建 、 维 护 索 引 。 
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(2) 利用 MySQL 语句 创建 、 修 改 视图 。 

(3) 通过 视图 查看 和 修改 基本 表 中 的 数据 。 

3. 实验 内 容 及 步 又 

(1) 索引 的 创建 与 管理 。 

CD Jy student 表 的 phone 列 上 建立 一 个 降序 普通 索引 phone_idx: 


mysql» create index phone idx on student(phone desc); 

© 在 course 表 的 cname 列 上 建立 一 个 唯一 性 索引 cname. idx: 

mysql» create unique index cname idx on course (cname); 

@ 在 score 表 的 studentno 和 courseno 列 上 建立 一 个 复合 索引 stu. cour. idx: 
mysql» create index stu cour idx on score(studentno, courseno); 

CD 在 teacher 表 上 建立 teacherno 主键 索引 ,建立 tname 和 prof 的 复合 索引 : 


mysql > alter table teacher 
-> add primary key(teacherno), 
一 > add index mark(tname, prof); 


© 删除 teacher 表 的 mark 索引 : 

mysql» drop index mark on teacherl; 

© 利用 alter table 语句 同样 可 以 删除 cname idx 索引 : 
mysql» alter table course drop index cname idx; 


(2) 利用 MySQL Workbench 创建 索引 。 

CD 进入 修改 表 student 界面 。 

© 打开 index 选项 卡 ,在 Index Name 的 文本 框 中 输入 索引 名 称 un. phone. £1 0 à 
Index Columns 会 自动 显示 表 student 中 的 所 有 列 名 ,选择 phone 列 。 

© 存储 类 型 选择 BTREE .选择 索引 类 型 unique, 表 示 创 建 唯一 性 索引 ,其 他 参数 采用 
默认 值 ,如 图 18-12 所 示 。 

© 设置 完成 后 , 单 击 Apply 按钮 ,出 现 脚 本 对 话 框 。 

© 单 击 Apply 按钮 ,进入 完成 对 话 框 , 单 击 Finish 按钮 , 即 可 完成 在 数据 库 teaching 中 
student 表 上 的 唯一 索引 un_phone 的 创建 。 

@ 也 可 以 在 此 界面 中 实现 索引 的 修改 和 删除 操作 。 

(3) 创建 和 管理 视图 。 

(D f£ teacher 表 上 创建 一 个 简单 的 视图 ,视图 名 称 为 v_teacher: 

mysql» create view v teacher 


一 > as select * from teacher; 
mysql» select * from v teacher; 


© f£ student 表 course 表 和 score 表 上 创建 一 个 名 为 stu. score 的 视图 。 视 图 中 保留 
19 级 的 女生 的 学 号 、. 姓 名 .电话 .课程 名 和 期 末 成 绩 : 
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图 18-12 ”创建 唯一 索引 


mysql> create view stu score 
-» as select student. studentno, sname, phone, cname, final 
->from score join student on student. studentno = score. studentno 
-> join course on course. courseno = score. courseno 
-» where sex= ' 女 ' and left(student. studentno,2) = '19'; 
mysql» select * from stu score; 


C) 创建 视图 v_teach ,统计 材料 学 院 的 教师 中 不 是 教授 或 副教授 的 教师 号 .教师 名 和 
专业 : 


mysql» create view v teach 
一 > as select teacherno, tname, major 
-» from teach viewl 


一 > where prof not like '% 教 授 ' and department = ' 材 料 学 院 '; 
@ 查看 视图 定义 情况 : 
mysql show create view stu score; 


C) 修改 视图 v_teach, 统 计 材 料 学 院 的 教师 中 的 教授 和 副教授 的 教师 号 ,教师 名 和 专 
业 , 并 在 视图 名 后 面 指明 视图 列 名 称 : 


mysql» alter view v teach (教师 号 ,教师 名 ,专业 ) 

一 > as select teacherno, tname, major 

一 > from teach viewl 

-> where prof like '% 教 授 ' and department- ' 材 料 学 院 ' ; 
mysql? select * from v teach; 
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( 删除 视图 v teach 的 命令 : 
mysql» drop view v teach; 


(4) 利用 MySQL Workbench 管理 视图 。 
CD 启动 MySQL Workbench 工具 ,选择 teaching 数据 库 , 展 开 Views 选项 ,在 如 图 18-13 所 
示 的 弹出 菜单 中 ,执行 Create View 命令 ,进入 文本 编辑 区 。 


SCHEMAS 
Q Fiter objects 
v B8 teaching 


* E Tables 
v3 Views 


| P» Re] stu score. — — — — — — — — —3À 
— E edens Select Rows - Limit 10 
> E] teach vi 
p [8] teach view 
By soredbocea Send to SUL Fditor 
> ÈP Functions. 








Copy to Clipboard 


Create View... 
Ater Vien... 
Drop Vie 
Refresh ALL 





E1813 创建 视图 


© 在 文本 编辑 区 ,输入 创建 视图 st view 的 代码 。 自 己 检查 无 误 后 , 单 击 Apply 按钮 。 
© 在 弹出 的 代码 对 话 框 中 , 单 击 Apply 按钮 , 单 击 Finish 按钮 完成 视图 创建 过 程 。 
CD 展开 Views 文件 夹 ,选择 视图 st_view ,执行 Select Rows-Limit 10 命令 , 即 可 观察 
到 输出 结果 。 
© 在 如 图 18-13 所 示 的 弹出 菜单 中 ,还 可 以 通过 执行 Alter View 命令 .Drop View fir 
令 来 修改 和 删除 视图 。 
(5) 利用 视图 修改 表 数 据 。 
CD 创建 视图 view_avg ,统计 各 门 课程 的 平均 成 绩 , 并 按 课程 名 称 升序 排列 ， 
mysql? create view view avg 
->as select cname 课程 名 ， avg(final) 平均 成 绩 
一 > from score join course on ”score. courseno = course. courseno 


一 > group by  cname asc; 
mysql» select * from view avg; 


© 通过 视图 v. teacher XE EA teacher 进行 插入 .更 新 和 删除 数据 的 操作 : 


mysql > insert into v teacher (teacherno, tname, major, prof, department) 

-> values ('t07027' ，" 陶 颐 年 ' ，' 合 金 技术 ' ，' 副 教授 ' ，" 材 料 学院 ' ); 
mysql» update v teacher set prof = ' 副 教授 ' where teacherno = 't07019'; 
mysql» delete from v teacher where teacherno = 't07027'; 


© 视图 stu. score 依赖 于 源 表 student, course 和 score 3 张 表 ,包括 studentno, sname, 
phone .cname 和 final 5 个 字段 ,通过 stu. score 修改 基本 表 student 中 的 学 号 为 19112100072 


的 电话 号 码 : 


mysql > update stu score set phone = '133123456777" 


-> where studentno = '19112100072'; 
mysql» select studentno, sname, phone from student 
一 > where studentno = '19112100072'; 


f stu score 是 针对 19 级 的 视图 ,验证 能 否 修改 18 级 数据 
mysql > update stu score set phone = 135123456777' 
-> where studentno = '18125121107'; 


CD 修改 v. teacher 的 视图 定义 ,添加 with check option 选项 : 


mysql > alter view v teacher 
-»as 
一 > select * from teacher 
-> where department = ' 计 算 机 学 院 ' 


一 > with check option ; 
A. 实验 报告 总 结 
COD 不 同类 型 索引 对 表 数 据 进行 查询 的 功能 。 
(2) 视图 与 数据 表 及 查询 的 区 别 。 
(3) 通过 视图 插入 ,修改 ,删除 基本 表 中 数据 的 注意 事项 。 


实验 8 MySQL 函数 的 创建 和 使 用 


1. 实验 目的 
(1) 掌握 自 定义 函数 的 格式 、 功 能 和 调用 过 程 。 
(2) 掌握 MySQL 控制 流 语句 的 基本 功能 和 分 类 。 
(3) 掌握 利用 控制 流 语句 实现 基本 的 分 支 选择 和 循环 处 理 的 功能 。 
(4) 了 解 其 他 控制 流 语句 的 功能 和 应 用 。 
2. 实验 预习 与 准备 
预习 主教 材 第 7 章 。 
(1) 利用 begin...end 语句 定义 语句 块 的 场合 。 
(2) 利用 if... else 语句 和 case 请 句 实现 分 支 选择 的 使 用 方法 。 
(3) 利用 循环 语句 实现 复杂 算法 处 理 的 过 程 。 
3. 实验 内 容 及 步 又 
(1) 会 话 变量 等 基本 操作 的 使 用 。 
使 用 查询 结果 给 变量 赋值: 
mysql» set @ sname = (select sname from student 
-> where studentno = '18135222201'); 


mysql» select studentno, sname, birthdate 
一 > from student where sname = @ sname; 


@ 利用 select 语句 将 表 中 数据 赋值 给 变量 : 


mysql» select @ sname := sname from student limit 5,1; 
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© 利用 select 语句 输出 表达 式 : 
mysql» select 1+7.5+3.4, '2018— 01- 20'+ interval 6 month; 
@ 改变 MySQL 命令 的 结束 标记 : 


mysql > delimiter $$ 
mysql > select studentno, sname, birthdate 

一 > from student where sname like ' 梅 %' $$ 
mysql» delimiter ; 


© 利用 预 处 理 SQL 语句 输出 course 表 中 的 前 5 行 记录 的 部 分 数据 : 


mysql > set @a= 5; 
mysql > prepare STMT 
一 > from "select courseno,cname,type, period from course limit ?"; 


mysql» execute STMT using (2a; 


(2) 自 定义 函数 的 创建 和 调用 。 
(D 创建 一 个 名 为 f_course 的 函数 返回 表 course 中 的 指定 课程 号 的 课程 名 : 


mysql > delimiter && 
mysql» create function f course(c no varchar(6)) 
-> returns char(6) 
一 > begin 
-» return (select cname from course 
-> where courseno -c no); 
一 > end && 
mysql > delimiter ; 


© 调用 函数 f course: 
mysql» select f course('c05109'"); 
C) 查看 指定 数据 库 ( 如 teaching) 中 的 所 有 自 定义 函数 名 : 


mysql» select name from MySQL. proc 
-> where db = 'teaching' and type = 'function'; 


CD 查看 指定 函数 f_course 的 信息 : 


mysql» select * from information schema. routines 
一 > where routine name- 'f course'; 


© 修改 存储 函数 E course 的 定义 。 将 读 写 权 限 改 为 reads. sql data, 并 加 上 注释 信息 


"find function name"; 


mysql» alter function f course 
一 > reads sql data 
一 > comment  'find function name'; 
mysql» select SPECIFIC NAME, SQL DATA ACCESS, 
一 > routine comment from information schema.Routines 


一 > where routine name- 'f course'; 


© 练习 利用 MySQL Workbench 工具 创建 修改 和 删除 过 程 函 数 。 
(3) 条 件 控制 语句 的 应 用 。 
CD 删除 表 course 中 指定 课程 号 在 score 中 的 记录 : 


mysql > delimiter $$ 
mysql» create function delete cno (c no char(6)) 
—» returns char(6) 
—» begin 
—» declare c name char(6); 
一 > select cname into c name from course where courseno = c no; 
-> ifc name is null then 
-» delete from score where courseno - c no; 
一 > return 'yes'; 
-> else 
一 > return 'no'; 
-> end if; 
-» end $$ 
mysql > delimiter ; 


© 创建 函数 ex_case, 通 过 case 语句 首先 判断 传人 参数 的 值 是 否 为 100, 如 果 条 件 成 立 
则 输出 1, 如 果 条 件 不 成 立 则 再 判断 该 传人 参数 的 值 是 否 为 200, 如 果 成 立 则 输出 2, 如 果 条 
件 不 成 立 则 再 判断 该 传人 参数 的 值 是 否 为 300, 如 果 成 立 则 输出 3, 当 以 上 条 件 都 不 满足 时 
输出 0。 


mysql > delimiter // 

mysql» create function ex case( x int) 
-» returns int 
一 > begin 
一 > case x 
-» when 100 then set x-1; 
-> when 200 then set x=2; 
-» when 300 then set x=3; 
-> else set x=0; 
—» end case; 
一 > return x; 
-> end // 

mysql» delimiter ; 

mysql» select exam case(127); 


(4) 循环 语句 的 应 用 。 
(D 定义 函数 ex. while. JH. while 语句 求 50 一 100 的 和 : 


mysql > delimiter // 
mysql» create function ex_while(n int) returns int 
一 > begin 
一 > declare sum int default 0; 
一 > declare m int default 50; 
-> while m< = ndo 
-> set sum= sum* m; 
-»set m=m+1; 
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—» end while; 
一 > return sum; 
-» end // 
mysql» delimiter ; 
mysql» select exam while(100); 


@ 定义 函数 ex. loop. JH loop ift &JoK 20— 70 的 和 。 通 过 leave 语句 退出 循环 并 输出 
结果 : 


mysql > delimiter// 
mysql» create function exam loop(n int) returns int 
一 > begin 
一 > declare sum int default 0; 
一 > declare m int default 20; 
一 > loop label:loop 
一 > set sum = sum + m; 
-»setm-mtl; 
-»if m»n then 
-> leave loop label; 
-> end if; 
一 > end loop; 
一 > return sum; 
-> end // 
mysql > delimiter; 
mysql > select exam loop(70); 
4. 实验 报告 总 结 
A) if...else 请 句 和 case 语句 实现 分 支 选择 的 区 别 。 
(2) while, loop, repeat 等 循环 语句 的 功能 和 区 别 。 
(3). RE if.. else 语句 的 特点 和 使 用 注意 事项 。 


实验 9 存储 过 程 的 创建 和 使 用 


1. 实验 目的 

(1) 掌握 存储 过 程 和 触发 器 的 基本 概念 和 功能 。 

(2) 掌握 创建 ,管理 存储 过 程 的 方法 。 

G) 掌握 创建 ,管理 触发 器 的 方法 。 

2. 实验 预习 与 准备 

预习 主教 材 第 8. 1 节 : 

(1) 存储 过 程 的 基本 概念 。 

(2) 利用 MySQL 语句 创建 .管理 存储 过 程 。 

(3) 利用 MySQL Workbench 工具 创建 ,管理 存储 过 程 。 

3. 实验 内 容 及 步 又 

COD 创建 存储 过 程 p_student, M student 表 中 检索 出 所 有 电话 以 135 开头 的 学 生 的 学 
号 .姓名 ,出 生日 期 和 电话 等 信息 : 


mysql > delimiter // 


mysql» create procedure p student() 
一 > reads sql data 
一 > begin 
一 > select studentno, sname, birthdate , phone 
一 > from student 
—» where phone like '135 $ 'order by studentno ; 
-> end // 
mysql» delimiter ; 
mysql» call p student(); 


(2) 创建 存储 过 程 pro. select O ,用 指定 的 学 号 和 课程 号 为 参数 查询 学 生成 绩 : 


mysql > delimiter $$ 
mysql» create procedure pro select(in s no char(11),c no char(6)) 
一 > begin 
-> select * from score 
一 > where studentno = s no and courseno- c no; 
-> end $$ 
mysql» delimiter ; 
mysql» call pro select('19122203567', 06127"); 


(3) 创建 一 个 存储 过 程 pro_insert() ,向 score 表 中 插入 一 行 记录 ,然后 创建 男 一 存储 过 
FE pro_out() ,调用 存储 过 程 pro. insert O ,并 查询 输出 score 表 中 插入 的 记录 : 


# 先 创建 第 1 个 存储 过 程 pro_insert() 
mysql» create procedure pro insert() 

-> insert into score values('19111133071', 'c08171',100,99); 
# 创建 第 2 个 存储 过 程 pro_out(), 调 用 pro insert() 
mysql > delimiter $$ 
mysql» create procedure pro out() 

一 > begin 

-> call pro insert(); 

-> select * from score 

一 > where studentno = '19111133071'; 

-> end $$ 
mysql> call do_out(); 


(4) 查看 存储 过 程 的 定义 : 


mysql» show procedure status like 'pro &'; 

mysql» show create procedure pro out; 

mysql» select * from information schema. routines 
一 > where routine name- 'pro out '; 

mysql > show create procedure p student; 


(5) 修改 存储 过 程 do_insert() 的 定义 。 将 读 写 权限 改 为 modifies sql data, 并 指明 调用 
者 可 以 执行 : 
mysql> alter procedure do insert 


一 > modifies sql data 
一 > sql security invoker; 


Sw: 
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(6) 利用 MySQL Workbench 工具 管理 存储 过 程 。 利 用 MySQL Workbench 工具 管理 
存储 过 程 主要 包括 对 存储 过 程 的 创建 、 修 改 、 查 看 、 删 除 和 执行 操作 。 

4. 实验 报告 总 结 

CD 存储 过 程 中 输出 参数 与 输入 参数 在 定义 、 调 用 时 的 区 别 。 

(2) 触发 器 insert、delete 和 update 操作 与 临时 表 inserted 和 deleted 的 关系 。 

(3) 存储 过 程 与 触发 器 的 联系 与 区 别 。 


实验 10 ”触发 器 .游标 和 事件 


1. 实验 目的 

(1) 掌握 游标 .事件 和 触发 器 的 基本 概念 及 功能 。 

(2) 掌握 创建 ,管理 触发 器 的 方法 。 

(3) 掌握 创建 ,管理 事件 的 方法 。 

(4) 掌握 游标 处 理 结果 集 的 基本 过 程 。 

2. 实验 预习 与 准备 

预习 主教 材 第 8. 2 一 8.4 节 ， 

(1) 触发 器 的 基本 概念 及 触发 器 与 存储 过 程 的 关系 。 

(2) 利用 MySQL 语句 创建 .管理 触发 器 。 

(3) 利用 MySQL 语句 创建 ,管理 游标 。 

(4) 利用 MySQL 语句 创建 ,管理 事件 。 

3. 实验 内 容 及 步 又 

CD 游标 的 创建 和 应 用 。 创 建 存储 过 程 pro cursorO ,利用 loop 循环 语句 控制 fetch 语 
句 来 检索 游标 teacher cursor 中 可 用 的 数据 : 


mysql > delimiter // 
mysql» create procedure pro cursor() 
=> begin 
-> declare v tno varchar(6) default ''; 
-> declare v tname varchar(8) default ''; 
-> declare teacher cursor cursor 
-> for select teacherno, tname from teacher; 
-> declare continue handler for not found set (Zdovar- 1; // 定 义 处 理 程序 
-> set @dovar = 0; 
—» open teacher cursor; 
一 > fetch Loop:loop 
一 > fetch teacher cursor into v tno,v tname; 
-> if @dovar = 1 then 
一 > leave fetch Loop; 
一 > else 
一 > select v tno,v tname; 
-> end if; 
一 > end loop fetch Loop; 
一 > close teacher cursor; 
-> select (dovar; 
—» end ; // 


mysql> delimiter ; 
mysql> call pro_cursor(); 


(2) 创建 一 个 触发 器 cno trigger 当 更 改 表 course 中 某 门 课 的 课程 号 时 ,同时 将 score 
表 课程 号 全 部 更 新 : 


mysql» delimiter $$ 

mysql > create trigger cno trigger after update 
一 > on course for each row 
一 > begin 
一 > update score set courseno = new. courseno 
-> where courseno = old. courseno; 
-» end $$ 

mysql» delimiter ; 

# 验 证 触发 器 cno_trigger 的 功能 

mysql> update course set  courseno = 'c08106" 
一 > where courseno- 'c07123'; 


mysql» select * from score where courseno = 'c08106'; 


(3) 创建 一 个 触发 器 stu trigger. MWER student 表 某 个 人 的 记录 时 , 则 删除 score 表 相 
应 的 成 绩 记 录 : 


mysql > delimiter $$ 

mysql > create trigger stu trigger after delete 
-> on student for each row 
一 > begin 
一 > delete from score where studentno = old. studentno; 
-» end $$ 

mysql > delimiter ; 

# 验证 触发 器 stu trigger 的 功能 

mysql» delete from student 
-» where studentno- '19123567897'; 

mysql» select * from score 
-> where studentno = '19123567897'; 


(4) 在 teacher 表 中 ,定义 一 个 触发 器 teach_trigger, 当 一 个 教师 的 信息 被 删除 时 ,把 该 
教师 的 编号 和 姓名 添加 到 delete teacher 表 中 : 


* 创建 一 个 空 表 delete teacher, 表 由 teacherno 和 tname 两 列 组 成 
mysql» create table delete teacher select teacherno, tname 
一 > from teacher where 1 = 0; 
# 创建 teacher 表 的 触发 器 
mysql» create trigger teach trigger 
-» after delete on teacher for each row 
-> insert into delete teacher(teacherno, tname) 
-»  values(old.teacherno, old.tname); 
# 验 证 触发 器 teach trigger 的 功能 
mysql» delete from teacher where tname- ' 常 杉 '; 
mysql» select * from delete teacher; 


(5) 事件 的 创建 和 管理 。 
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(D 创建 现在 立刻 执行 的 事件 direct 1.8028 — 4 test: 





mysql» create event direct 1 
->on schedule at now() 
-» do 


一 > create table test(timeline timestamp); 
© 创建 事件 test insert. f$ 15 秒 插入 一 条 记录 到 数据 表 test: 


mysql» create event test insert 
一 > on schedule every 15 second 
-> do 


-> insert into test values(current timestamp); 


@ 创建 事件 startdays ,要求 从 下 周 开 始 ,每 天 都 清空 test 表 ,并 且 在 2018 年 的 09 H 08 
日 12:00 时 结束 : 
mysql > delimiter $$ 
mysql > create event startdays 
->on schedule every 1 day 
-> starts curdate() + interval 1 week 
-» ends '2018 - 09 - 08 12:00:00" 
一 > do 
一 > begin 
-»  truncate table test; 
-» end $$ 
mysql > delimiter; 


CD 查看 startdays 的 创建 信息 : 
mysql > show create event startdays; 
© 删除 事件 startdays 的 代码 如 下 : 
mysql > drop event startdays; 


4. 实验 报告 总 结 

(1) 触发 器 和 事件 在 定义 .调用 时 的 区 别 。 

(2) 触发 器 中 insert, delete 和 update 操作 与 临时 表 old 与 new 的 关系 。 
(3) 存储 过 程 与 触发 器 的 联系 和 区 别 。 


实验 11 ACE ede d du 


1. 实验 目的 

(1) 掌握 事务 和 锁 的 基本 概念 。 

(2) 掌握 事务 的 定义 ,管理 及 利用 事务 进行 数据 处 理 的 过 程 。 
(3) 了 解 MySQL 的 并 发 控制 及 锁 的 管理 等 相关 技术 。 

2. 实验 预习 与 准备 

预习 主教 材 第 9 章 : 

CD 事务 的 特点 和 分 类 。 


(2) 事务 的 启动 .保存 .提交 、 回 滚 操 作 语 句 。 

(3) 定义 隔离 级 别 实现 事务 访问 资源 和 数据 的 隔离 。 

(4) 锁 的 类 型 和 管理 。 

3. 实验 内 容 及 步 又 

CD 创建 存储 过 程 auto_delete, 利 用 事务 删除 课程 号 为 c05109 的 表 记 录 ,然后 回 滚 ; 


mysql > delimiter // 

mysql» set @@autocommit = 0; 
一 > create procedure auto delete() 
一 > begin 
一 > start transaction; 
一 > delete from course where  courseno = 'c05109'; 
一 > select * from course where  courseno- 'c05109'; 
一 > rollback; 
一 > select * from course where courseno = 'c05109'; 
-> end// 

# 调用 存储 过 程 auto delete() 

mysql» call auto delete(); 


(20 创建 存储 过 程 tran_update, 启 用 事务 将 课程 表 course 中 课程 号 为 c05109 的 课程 
名 称 改 为 “MySQL 数据 库 ”, 并 提交 该 事务 : 


mysql > delimiter // 
mysql > create procedure tran update() 
一 > begin 
一 > start transaction; 
一 > update course set cname = 'MySQL 数据 库 ' 
一 > where courseno = 'c05109'; 
一 > commit; 
-> select * from course where courseno = 'c05109'; 
-» end// 
mysql» delimiter ; 
# 调用 存储 过 程 tran update() 
mysql» call tran update(); 


(3) 定义 事务 ,向 course 表 中 添加 一 条 记录 ,并 设置 保存 点 。 然 后 再 删除 该 记录 ,并 回 
深 到 事务 的 保存 点 ,提交 事务 : 


mysql > delimiter // 
mysql > create procedure tran save() 
一 > begin 
一 > start transaction; 
一 > insert into course 
-> values('c05179', 'UML E BE ', ' 选 修 ',48, 12,7); 
一 > savepoint spcnol; 
一 > delete from course 
一 > where courseno = 'c05179'; 
一 > rollback work to  savepoint spcnol; 


一 > select * from course where courseno = 'c05179'; 
一 > commit ; 
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-» end // 
mysql> delimiter ; 
# 调用 存储 过 程 tran_save() 
mysql» call tran save(); 


(4) 创建 存储 过 程 tran_student, 启 用 事务 实现 在 student 表 上 进行 查询 、 插 和 人、 更 新 和 
删除 数据 操作 : 


mysql > delimiter // 
mysql» create procedure tran student() 
一 > begin 
一 > start transaction; 
一 > select studentno, sname 
一 > from student 
一 > where studentno- '19123567897'; 
-> insert into student values('1928261007', f] FEL, 
=> ' 女 ','1999 - 09 - 19', 779, '1318909876', 'sdch@163. con') ; 
-> update student set sname = ' 孙 释 南 ' 
一 > where studentno = '19123567897'; 
一 > commit ; 
-> end // 
mysql» delimiter ; 
mysql» call tran student(); 
mysql > select studentno, sname, birthdate 
-> from student where sname like 'f] % '; 


(5) 锁 的 管理 。 
CD 查看 系统 变量 @@tx_isolation 中 存储 事务 的 隔离 级 : 


mysql» select (2(2tx isolation 

© 在 student 表 上 设置 一 个 只 读 锁 定 : 
mysql > lock tables student read; 

O 在 student 表 上 设置 一 个 写 锁定 : 
mysql > lock tables student write; 

(D 解锁 表 : 

mysql > unlock tables; 


4. 实验 报告 总 结 

(1) 并 发 数据 访问 引发 的 问题 及 解决 方案 。 
(2) 回 滚 和 检查 点 的 作用 。 

(3) 如 何 避 免 出 现 死 锁 。 


实验 12 MySQL 的 安全 管理 


1. 实验 目的 
(D 了 解 MySQL 的 权限 系统 的 工作 原理 。 


(2) 掌握 MySQL 账户 安全 管理 的 基本 操作 。 

(3) 掌握 MySQL 权限 安全 管理 的 基本 操作 。 

2. 实验 预习 与 准备 

预习 主教 材 第 10 章 : 

(1) MySQL 的 权限 机 制 与 权限 管理 。 

(2) 账户 管理 的 基本 操作 。 

(3) 权限 管理 的 基本 操作 。 

3. 实验 内 容 及 步 双 

(1) MySQL 命令 的 使 用 。 

CD 使 用 root 用 户 登录 到 本 地 MySQL 服务 器 的 teaching 库 中 : 
mysql -uroot -p - hlocalhost teaching 

© 使 用 root 用 户 登录 到 本 地 MySQL 服务 器 的 teaching 库 中 ,执行 一 条 查询 语句 : 
mysql -uroot - p - hlocalhost teaching - e "desc student;" 

© 使 用 mysqladmin 将 root 用 户 的 密码 修改 为 "123457”: 
mysqladmin -u root - p password "123457" 


(D 使 用 update 语句 将 root 用 户 的 密码 修改 为 "pwd1357”: 


mysql» update mysql. user set password = password("pwd1357") 
一 > where user - "root" and host = "localhost"; 


© 使 用 set 语句 将 root 用 户 的 密码 修改 为 “pwd258”: 

mysql» set password password("pud258") ; 

(2) 普通 用 户 的 管理 。 

CD 使 用 create user 创建 一 个 用 户 ,用 户 名 是 jef ,密码 是 mypass, 主 机 名 是 localhost: 

mysql» create user 'jef'@'localhost' identified by 'nyword'; 

© 使 用 drop user 删除 用 户 'jeff'@ localhost" : 

mysql» drop user 'jeff'() 'ocalhost'; 

© 使 用 grant 语句 创建 一 个 新 的 用 户 usertest. 密码 为 testpwd。 用 户 usertest 对 所 有 
的 数据 有 查询 和 更 新 权限 ,并 授予 对 所 有 数据 表 的 select 和 update 权限 : 


mysql» grant select ,update on *.* to 'usertest'(2 'localhost' 
一 > identified by 'testpwd'; 

mysql» select Host,User,Select priv,Update priv, from mysql. user 
一 > where user = 'usertest'; 


CD 使 用 insert 创建 一 个 新 账户 ,其 用 户 名 称 为 cust. 主机 名 称 为 localhost, 密码 为 


customerl: 


mysql» insert into user (Host, User, Password) 
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一 > values( 'localhost', 'cust', password( 'customer1')); 
© 使 用 delete 删除 用 户 'cust'@ localhost": 


mysql» delete from mysql.user 
一 > where host = 'localhost' and user- 'cust'; 


© 使 用 set 语句 将 usertest H P 的 密码 修改 为 “newpwdone” 
mysql» set password for 'usertest'@ 'localhost' = password("newpwdone" ) ; 
CD 使 用 update 语句 将 usertest 用 户 的 密码 修改 为 "newpwdtwo”: 


mysql» update mysql. user set Password = password("newpwdtwo") 
—» where User= "usertest" and Host = "localhost"; 


使 用 grant 语句 将 usertest 用 户 的 密码 修改 为 “newpwd3”: 


mysql» grant usage on *. * to 'usertest'(à 'localhost' 
-> identified by 'newpwd3'; 
(3) 权限 管理 。 
CD 使 用 grant 语句 创建 一 个 新 的 用 户 grantuser, 密 码 为 grantpwd。 用 户 grantuser 对 
所 有 的 数据 有 查询 .插入 权限 ,并 授予 grant BUR : 
mysql» grant select , insert on *. * to 'grantuser'(2 'localhost' 
-> identified by 'grantpwd" 
一 > with grant option; 
mysql» select Host,User,Select priv,Insert priv, grant priv 


一 > from mysql. user 


一 > where user = 'grantuser'; 


© 使 用 revoke 请 句 取 消 用 户 grantuser 的 更 新 权限 : 


mysql» revoke update on * . * from 'grantuser'@ 'localhost'; 
mysql» select Host,User,Select priv,Update priv,Grant priv 
一 > from mysql. user 
一 > where user = 'usertest'; 


© 使 用 show grants 语句 查询 用 户 grantuser 的 权限 信息 : 
mysql» show grants for 'grantuser'(9 'localhost'; 
CD 收回 grantuser JH P! Xf teaching 数据 库 中 course 表 的 update 权限 : 


mysql» revoke update on teaching. course 
一 > from grantuser(d localhost; 


© BET grantuser 每 小 时 可 以 发 出 的 查询 数 18 次 ,每 小 时 可 以 连接 数据 库 5 次 ,每 小 
时 可 以 发 出 的 更 新 数 为 15 次 的 权限 : 
mysql» grant all on * . * to grantuser@]localhost 


一 > identified by 'grantpass" 
一 > with max queries per hour 18 


一 > max updateS per hour 15 


一 > max connections per hour 10; 
© 使 用 revoke 语句 收回 grantuser 用 户 的 所 有 权限 ,包括 grant 权限 : 


mysql» revoke all privileges, grant option 
一 > from grantuser(4 localhost; 


4. 实验 报告 总 结 
(OD MySQL 系统 的 安全 机 制 的 优 缺 点 。 


(2) MySQL 数据 库 安 全 管理 中 要 注意 的 问题 。 
(3) 授予 权限 和 撤销 权限 的 关系 。 


实验 13 备份 和 恢复 


1. 实验 目的 

(1) 了 解 备份 和 恢复 数据 库 的 备份 策略 的 选择 。 
(2) 掌握 备份 数据 库 的 基本 操作 。 

(3) 掌握 恢复 数据 库 的 基本 操作 。 

(4) 掌握 表 的 导入 导出 的 基本 操作 。 

2. 实验 预习 与 准备 

预习 主教 材 第 11 章 : 

(1) 备份 和 还 原 的 时 机 与 类 型 。 

(2) 备份 数据 库 的 方法 与 步骤 。 

(3) 还 原 数据 库 的 方法 与 步骤 。 

(4) 表 数 据 的 导入 导出 步骤 。 

3. 实验 内 容 及 步 又 

(1) 使 用 mysqldump 备份 数据 库 和 表 。 

(D EJH mysqldump 命令 备份 数据 库 teaching 中 的 所 有 表 : 


mysqldump — u root - p teaching > f:/backup/teaching 20180101. sql 

© 备份 teaching 数据 库 中 的 teacher X: 

mysqldump — u root - p teaching teacher > f:/backup/teacher 20180101.sql 
© 使 用 mysqldump 备份 teaching 和 mysqltest 数据 库 : 


mysqldump -u root -p -- databases teaching mysqltest 
> f :\backup Vteach testdb 20180101.sql 


CD WEH mysqldump 备份 服务 器 中 的 所 有 数据 库 : 
mysqldump -u root -p --all-databases >f:/backup/alldb. sql 
© 使 用 mysqlhotcopy 备份 mysqltest 数据 库 到 /usr/backup 目录 下 : 


mysqlhotcopy -u root -pmysqltest /usr/backup 
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(2) 数据 恢复 。 
(D 使 用 mysql 命令 将 f:\backup\teaching_20180101. sql 文件 中 的 备份 导入 到 数据 
EP: 


mysql 一 u root- p teaching < f: /backup/teaching_20180101. sql 
© 使 用 root 登录 到 服务 器 ,使 用 source 导入 本 地 的 备份 文件 teaching. 201800101. sql: 


mysql > use teaching; 
mysql > source f:/backup/teaching 201800101.sql 


(3) 从 mysqlhotcopy 拷贝 的 备份 恢复 数据 库 : 
cp -r /usr/backup/mysqltest usr/local/mysql/data 


(3) 数据 库 迁 移 。 将 www. a123. com 主机 上 的 MySQL 数据 库 全 部 迁移 到 www. 
b123. com 主机 上 。 在 www. abc123. com 主机 上 执行 的 命令 如 下 : 


mysqldump — h www.al23.com - uroot - ppassword dbname | 
mysql — hwww.b123.com - uroot - ppassword 


(4) 数据 的 导入 导出 。 

CD 使 用 select... into outfile 将 teaching 数据 库 中 的 student 表 中 的 记录 导出 到 文本 
文件 : 

mysql» select * from teaching. student into outfile 'f:/student. txt'; 


© 使 用 select ...into outfile 将 teaching 数据 库 中 的 student 表 中 的 记录 导出 到 文本 文 
件 , 使 用 fields 选项 和 lines 选项 ,要 求 字 段 之 间 使 用 逗号 ", "间隔, 所 有 字段 值 用 双 引 号 括 
起 来 ,定义 转 义 字符 定义 为 单 引 号 “\'”: 


mysql» select * from teaching. student into outfile 'f:/student01. txt' 
-> fields 
-> terminated by '," 
-> enclosed by V"' 
一 > escaped by 'V'' 
=> lines 


-> terminated by '\r\n'; 
© 使 用 select ...into outfile 将 teaching 数据 库 中 的 student 表 中 的 记录 导出 到 文本 文 
件 , 使 用 lines 选项 ,要 求 每 行 记录 以 字符 串 “>” 开 始 , 以 “< end >" 字 符 串 结尾 。 


mysql> select * from teaching. student into outfile "f:/student02. txt" 
一 > lines 
-> starting by ^ ' 
-> terminated by < end>'; 


CD fi Hi mysqldump 将 teaching 数据 库 中 的 student 表 中 的 记录 导出 到 文本 文件 : 


mysqldump - t f:/ teaching student -u root - p 


© ff FH mysqldump 命令 将 teaching 数据 库 中 的 student 表 中 的 记录 导出 到 文本 文件 ， 
使 用 FIELDS 选项 ,要 求 字 段 之 间 使 用 逗号 ”, ”间隔 ,所 有 字符 类 型 字段 值 用 双 引 号 括 起 来 ， 
定义 转 义 字符 定义 为 问号 *?”, 每 行 记录 以 回 车 换行 符 “\rn\n” 结 尾 : 

mysqldump - t f:\backup teaching student -u root - p 

—- fields - terminated- by = , 

—- fields - optionally - enclosed- by = V" 

—- fields - escaped- by = ? 

—- lines- terminated - by = \r\n 


© fii JH MySQL 语句 导出 teaching 数据 库 中 student 表 中 的 记录 到 文本 文件 : 
mysql -u root -p 
-- execute = "select * from student; " teaching > f:\student3. txt 
CD 使 用 load data 命令 将 f: Nstudent, txt 文件 中 的 数据 导入 到 teaching 数据 库 中 的 
student X: 


mysql > Load data infile 'f:/student.txt' into rable teaching. student; 
4. 实验 报告 总 结 

(D. MySQL 数据 库 的 备份 策略 选择 。 

(2) 还 原 数 据 库 需 要 注意 的 问题 。 


实验 14 性 能 优化 和 日 志文 件 管理 


1. 实验 目的 

(1) 掌握 MySQL 性 能 优化 的 概念 和 原理 。 
(2) 掌握 利用 日 志文 件 的 分 类 和 功能 。 

(3) 学 会 利用 日 志文 件 优化 数据 库 的 操作 。 
2. 实验 预习 与 准备 

预习 主教 材 第 12 章 和 第 13 章 。 

(1) MySQL 性 能 优化 的 基本 常用 方法 。 
(2) 优化 查询 和 优化 数据 库 结 构 方法 。 

(3) 日 志文 件 的 启用 、 查 看 ,删除 等 常见 操作 。 
3. 实验 内 容 及 步 又 

(1) MySQL 性 能 优化 参数 的 查看 和 设置 。 
CD 查询 慢 查 询 次 数 ， 


mysql > show status like 'Slow queries'; 
© 查询 MySQL 数据 库 的 查询 缓冲 区 的 大 小 : 


mysql» show variables like 'query cache size '; 


O 设置 查询 缓冲 区 的 系统 变量 ， > 
mysql» set @@global. query_cache_limit = 67108864; 部 
分 
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@ 关闭 查询 缓冲 区 : 


mysql» use MYSQL; 
mysql» set (2(JQuery cache type = 0; 


(2) 优化 查询 。 
(D 使 用 explain 语句 分 析 一 个 查询 语句 : 


mysql» explain select * from score; 

© 使 用 describe 命令 分 析 查 询 语 句 : 

mysql» describe select * from course; 

© 分 析 索 引 对 查询 速度 的 影响 ,在 未 使 用 索引 时 的 查询 情况 ， 
mysql> explain select * from student where phone = '13112345677'; 


© 使 用 explain 语句 执行 查询 命令 ,应 用 like 关键 字 , 且 匹 配 字符 串 中 含有 百 分 
S^", 


mysql» explain select * from student where sname like 'Xl $ ^G 
mysql» explain select * from student where sname like '% 梅 \G 


© 通过 explain 来 分 析 应 用 多 列 索 引 的 命令 。score 表 中 有 索引 studentno-- courseno. 
分 别 用 这 两 个 字段 进行 查询 分 析 : 
mysql» explain select * from score where studentno = '19 $ AG 


mysql» explain select * from score where courseno = 'c03 $ AG 


(3) 优化 数据 库 结 构 。 
(D 分 析 student 表 的 运行 情况 , 先 使 用 show index 语句 来 查看 索引 的 散 列 程度 ,然后 
可 以 使 用 analyze table 进行 修复 : 


mysql > show index from student\G; 
mysql> analyze table student ; 


© Fi ft student 的 运行 情况 : 

mysql > Check Table student; 

© 利用 optimize table 语句 优化 student 表 : 
mysql optimize table student; 

@ 将 查询 时 间 超 过 2 秒 的 查询 作为 慢 查 询 : 


mysql» set long query time= 2; 
mysql» show variables like 'long $% '; 


C) 查询 student 表 高 速 缓存 运行 中 的 反应 结果 : 


mysql» set @@global. query cache size-1; 
# 使 用 查询 高 速 缓存 运行 结果 


mysql» select sql cache * from teacher; 
# 未 使 用 查询 高 速 缓存 运行 结果 


mysql» select sql no cache * from teacher; 

(4) 错误 日 志 的 管理 。 

(D 使 用 记事 本 查看 MySQL 错误 日 志 : 

mysql» show variables like 'log error'; // 查 找到 错误 文件 用 记事 本 打开 
© EJH mysqladmin 命令 来 开启 新 的 错误 日 志 : 

C:\> mysqladmin -u root - p flush - logs 

C) 删除 错误 日 志 : 

mysql» flush logs; 

(5) 二 进 制 日 志 管理 。 

CD 使 用 show variables 语句 查询 日 志 设置 : 

mysql > show variables like 'log *'; 

© 使 用 show binary logs 查看 二 进 制 日 志文 件 的 个 数 及 文件 名 : 
mysql» show binary logs; 

C) 使 用 mysqlbinlog 查看 二 进 制 日 志 PGabc-bin. 0001; 


C:\Users\Administrator 
> mysqlbinlog C:\ProgramData\MySQL\MySQL Server5.7 \Data\PGabc - bin. 0001 


@ 使 用 purge master logs 删除 创建 时 间 比 PGabc-bin. 0003 -FIA H EXP: 
mysql> purge master logs TO 'PGabc - bin. 0003'; 

© 使 用 purge master logs 删除 2018 4E 6 H 12 日 前 创建 的 所 有 日 志文 件 : 
mysql > purge master logs before '20180612'; 


© 使 用 二 进 制 日 志 恢 复数 据 库 。 使 用 mysqlbinlog 恢复 MySQL 数据 库 到 2018 年 6 
月 12 日 17:00:00 时 的 状态 : 
C:\> mysqlbinlog - stop- date = "2018 - 06 — 12 17:00:00" 
C:\Documents and Settings\All UsersVMySQL 


MMySQL Server 5. 7\Data\ PGabc - bin. 0018 -uroot -p 
Enter password: ****** 


4. 实验 报告 总 结 
OD MySQL 性 能 优化 的 优点 。 
(2) MySQL 日 志 管 理 的 用 途 。 
实验 15 PHP 管理 MySQL 数据 表 


1. 实验 目的 
Q) 掌握 PHP 语言 的 优势 和 基本 运行 操作 。 


Y Wm 
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(2) 掌握 搭建 MySQL -- PHP 集成 环境 的 步骤 。 
(3) 掌握 使 用 PHP 操作 数据 库 的 基本 操作 。 

2. 实验 预习 与 准备 

预习 主教 材 第 14 章 : 

(D PHP 请 言 的 特点 和 工作 管理 。 

(2) 创建 和 运行 PHP 程序 的 步骤 。 

(3) 利用 PHP 连接 MySQL 数据 库 的 方法 。 

3. 实验 内 容 及 步 又 

(1) 认识 和 了 解 PHP 语言 的 基本 操作 。 

O 表达 式 的 输出 : 


<?php 

echo 5+5; //10 
echo '<br>'; 

echo 6 - 4; //2 
echo < br>'; 

echo 3 * 4; //2 
echo < br>'; 

echo 3/2; //1.5 
echo < br>'; 

echo 5 % 7; //5 
echo < br>'; 

echo 2 ** 3; //8 (PHP7.1.6) 
?> 


© PHP 语言 中 if...else 语句 的 认识 : 


«?php 

$ score = 85; 

if( $ score» - 90 ){ 
echo ' 优 秀 '; 

Jelseif( $ score>= 80 )( 
echo ' 良 好 '; 

Jelseif( $ score>= 70 )( 
echo ' 中 等 '; 

Jelseif( $ score>= 60 ){ 
echo ' 及 格 '; 

}else{ 
echo ' 不 及 格 '; 

) 


ked 


@ PHP 语言 中 for 语句 的 认识 : 


<?php 
$ sum = 0; // 用 于 保存 1 一 100 的 奇数 和 
for( $i = 1; $i<= 100; ++ $ i)( 
if($i %2 == 0){ // 若 为 偶数 , 则 不 累加 
continue; // 结 束 本 次 循环 


) 
$sum += $i; // 累 加 奇数 


} 
echo ' $ sum = '. $ sum; // $ sum = 2500 
?> 


@ PHP 语言 中 while 语句 的 认识 : 


while( $i»0)( 
echo $i--; // 循 环 输出 1654321 
) 


?> 


(2) 利用 PHP 语言 查询 数据 表 teacher 中 的 数据 


<?php 
$ conn1 = nysqli connect("localhost","root","123456"); 
$ select = mysqli_select_db( $ connl, teaching"); // 连 接 服务 器 中 的 teaching 


if( $ select) 
{ 
header( "Content - Type: text/html; charset = gb2312"); // 设 置 字符 集 

echo "数据 库 连 接 成 功 !"”; // 判 断 是 否 连接 成 功 

) 

$query = "select * from teacher"; 

$ result = mysqli query( $ connl, $ query) or die("Zrifij A Wr!" .mysgli error()); 

echo mysqli affected rows( $ connl); 

?> 


(3) 利用 PHP 语言 更 新 数据 表 student 中 的 数据 : 


<?php 
$ connl = mysqli_connect("localhost", "root", "123456" ) ; // 连 接 MySQL 服务 器 
$ select = mysqli_select_db( $ connl, teaching"); // 连 接 服 务 器 中 的 teaching 


if( $ select) 
{ 


header( "Content ~ Type: text/html; charset = gb2312"); // 设 置 字符 集 
echo "数据 库 连 接 成 功 !"; // 判 断 是 否 连接 成 功 
$ sqldelete = " update score set final = 89 where studentno = '19122111208' and courseno = 
' c06127'"; 
mysqli query( $ conn, $ sqldelete); 
?> 
# 检 测 更 新 数据 


mysql» select * from score 
-> where studentno = '19122111208' and courseno- ' c06127'; 


(4) 查询 课程 号 为 c05109 的 成 绩 信息 ,并 利用 输出 命令 echo 和 print_r() 函 数 两 种 方 
式 输出 : 


<?php 
$ connl = nysqli connect("localhost","root","123456"); // 连 接 MySQL 数据 库 服务 器 
$ select = mysqli_select_db( $ connl, "teaching"); // 连 接 服务 器 中 的 teaching 
if( $ select)( 

header( "Content - Type:text/html;charset = gb2312"); // 设 置 字符 集 

echo "数据 库 连 接 成 功 !”; // 判 断 是 否 连接 成 功 
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) 
$ sql = "select * from score where courseno = 'c05109';"; 
if ($result = mysqli query( $ conni, $ sql)) 
t 
while ( $ row= mysqli fetch assoc( $ result)) 
{ 
echo "<br />"; 
echo "echo 格式 : "."« br />"; 
echo "学 号 ". $ row[ 'studentno']; 
echo " 课程 号 ". $ row[ 'courseno']; 
echo " 平时 成 绩 ". $ row[ 'daily!]; 
echo " 期 末 成 绩 ". $ row[ 'final']. "<br/>"; 
echo "print_r() 函 数 格式 : "."< br />"; 
print r( $ row); 
) 
mysqli free result( $ result); // 释 放 内 存 
} 
mysqli close( $ connl); // 关 闭 连 接 对 象 
?> 
4. 实验 报告 总 结 
(D 配置 PHP-- MySQL 集成 环境 的 注意 事项 。 
(2) 利用 PHP 连接 MySQL 数据 库 的 步骤 。 


实验 16 综合 练习 


1. 实验 目的 

COD 使 用 可 视 化 工具 phpMyAdmin 的 基本 操作 。 

(2) MySQL 数据 库 和 表 的 常用 操作 。 

(3) MySQL 数据 库 对 象 的 常用 操作 。 

(4) MySQL 数据 库 的 备份 还 原 , 数 据 导入 导出 ,日 志 管 理 、 事 务 和 锁 的 可 视 化 操作 。 

2. 实验 预习 与 准备 

预习 本 书 第 17 章 : 

(1) 可 视 化 工具 phpMyAdmin 的 安装 和 配置 。 

(2) 可 视 化 工具 phpMyAdmin 的 功能 。 

(3) phpMyAdmin 与 MySQL 数据 库 连 接 的 步骤 。 

3. 实验 内 容 及 步 又 

(1) 数据 库 的 基本 操作 。 通 过 phpMyAdmin 登录 MySQL 后 ,phpMyAdmin 的 主 界面 
如 图 18-14 所 示 。 

C 创建 数据 库 。 单 击 左边 窗口 的 “新 建 ”按钮 ,进入 如 图 18-15 所 示 的 创建 数据 库 页 
i. 首先 在 文本 框 中 输入 数据 库 的 名 称 carsales_info, 然 后 在 下 拉 列 表 框 中 选择 所 要 使 用 
的 编码 ,一般 选择 gb2312 Chinese ci 简体 中 文 编码 格式 , 单 击 “ 创 建 " 按 钮 , 即 可 创建 数据 
库 carsales_info。 成 功 创建 数据 库 后 ,carsales_info 数据 库 将 显示 在 左 侧 窗口 的 界面 。 

说 明 : 在 右 侧 界面 中 可 以 对 该 数据 库 进行 相关 操作 ,如 数据 库 .SQL、 账 户 、 导 出 、 导 入 、 
设置 .二 进 制 日志、 复制. 变量、 字符 集 、 插 件 等 , 单 击 相应 的 超 链 接 进入 相应 的 操作 界面 。 还 
可 以 观察 到 数据 库 服务 器 、 网 站 服务 器 和 phpMyAdmin 的 参数 信息 。 
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图 18-14. phpMyAdmin 的 主 界面 
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图 18-15 创建 数据 库 


© 删除 数据 库 。 单 击 “ 数 据 库 ? 超 链接 ,进入 如 图 18-16 所 示 的 界面 中 。 要 删除 某 个 数 
据 库 , 如 student, 首 先 在 数据 库 左 侧 选择 该 数据 库 , 然 后 单 击 下 面 的 “删除 ?按钮 ,进入 如 
图 18-17 所 示 的 对 话 框 中 , 单 击 “ 确 定 ” 按 钮 , 即 可 成 功 删 除 指定 的 数据 库 。 





| SRE “排序 规则 主 复制 


O sakila 





国 booksngt 

O carsales info £b2312 chinese ci y 已 复制 a- 检查 权限 

国 db examsysten t£ general ci ^ 已 夏 制 查 权限 

| information schema ^ wtf general ci ^ 已 夏 制 ERR 
nysql wtf general ci ^ CE az 检查 权限 

O nysaltest hk chinese si y? 已 复制 =: 检查 权限 


performance schema 





e | 
wtf) ceneral ci sy CEH a3 检查 权限 






utf general ci e 已 复制 as 检查 权限 
ctf) ceneral ci ef 已 复制 =: 检查 权限 





ctfü general ci e 已 夏 制 























a 

j " fHEZSWIS—TL:dEBE! 您 真 的 要 执 
国 teaching gb2312 chinese ci 已 复制 ms 检查 权限 fI"DROP DATABASE "student ;"I* 
O world mtf general ci e CES a- 检查 权限 

atfB. ei 
确定 取消 
t. B $à& Bem. gg 
图 18-16 ”修改 数据 库 图 18-17 ”删除 数据 库 





MySQL 4t 48 Æ 85 3: Je d 95 XE E 


EXE 


^ 
" 


Y 


MySQL 4t 46 E JH 5 JFK AE E EAF 





(2) 数据 表 的 基本 操作 。 选 择 新 建 的 数据 库 carsales_info ,在 该 数据 库 中 可 以 创建 、 修 
改 和 删除 数据 表 。 

(D 创建 数据 表 。 创 建 数据 库 carsales_info 后 ,进入 如 图 18-18 所 示 的 页 面 。 在 该 操 
作 页 面 中 输入 数据 表 的 名 称 ( 如 carsinfo) 和 字段 数 ,然后 单 击 * 执 行 ?按钮 , 即 可 进入 如 
图 18-19 所 示 的 创建 数据 表 carsinfo 的 页 面 。 依 次 按照 预先 设计 好 的 数据 表 结 构 输 入 字段 
名 、 选 择 字段 类 型 .输入 字段 长 度 等 ,还 可 以 按照 如 图 18-20 所 示 创 建 主键 索引 。 输 入 完毕 ， 
单 击 “ 执 行 ”按钮 , 即 可 完成 数据 表 carsinfo 的 结构 创建 ,如 图 18-21 所 示 。 
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图 18-18 新 建 数据 表 
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18-20 创建 主键 
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18-21 ”完成 表 结 构 创 建 


成 功 创建 数据 表 carsinfo 后 ,将 显示 数据 表 结构 界面 。 在 表单 中 对 各 个 字段 的 详细 信 
息 进 行 录 入 ,包括 字段 名 、 数 据 类 型 .长度 / 值 .排序 规则 ,是 否 为 空 .主键 等 ,以 完成 对 表 结 构 
的 详细 设置 。 

© 添加 记录 。 在 图 18-21 所 示 的 数据 表 结 构 页 面 中 单 击 “ 插 和 人 ?按钮 ,依次 输入 各 字段 
的 值 ,如 图 18-22 Bros ,输入 完毕 单 击 * 执 行 ? 按 钮 ,完成 一 行 记录 的 输入 。 按 照 此 方式 可 以 
输入 余下 的 记录 ,输入 完毕 , 单 击 * 浏 览 "按钮 ,如 图 18-23 所 示 。 
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18-22 ”添加 记录 


@ 修改 记录 。 如 果 需 要 修改 记录 ,可 以 单 击 图 18-23 所 示 的 每 一 行 记录 的 “编辑 ” 按 
钮 ,进入 如 图 18-24 所 示 的 修改 记录 对 话 框 ,修改 相关 数据 项 。 修 改 完毕 , 单 击 “ 执 行 ” 按 
钮 即 可 。 此 时 还 可 以 单 击 此 页 下 面 的 “预览 SQL 语句 ?按钮 ,出 现 如 图 18-25 所 示 的 对 
话 框 。 

CD 按照 此 方法 ,可 以 创建 其 他 表 , 并 输入 相关 记录 。 也 可 通过 MySQL 客户 端 窗口 执 
行 相关 操作 。 数 据 库 carsales_info 的 6 个 表 的 结构 和 数据 录入 完成 后 ,界面 如 图 18-26 
所 示 。 
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REO v 上 汽车 编号 汽车 型 号 m f: 7 t. z 出 三 日 期 ni SEAM 
Ej J 编辑 gc 夏 制 Q NIS 170111 标致 东风 汽车 2017-01-01 177800 小 型 车 
D J 编辑 Rc EH Q WU 170212 BS B& 吉利 汽车 2017-02-11 29700 AE 
D J 编辑 xc 夏 制 Q WM 170314 Lid Bae 长 安 轿车 2017-02-11 34400 ”微型 车 


D J 编辑 xc 夏 制 Q MTs ”大众 POLO0 ”绿色 上 海 大 众 2017-03-11 53900 小 型 车 
E) J A zi Edl @ MIÈ 170516 新 威驰 Be 一 汽 丰田 2016-10-01 49800 小 型 车 
口 J 编辑 xc 夏 制 Q NI 170715 HEZITA AB 上 汽 通用 雪佛兰 2017-08-21 73900 FENE 
E) J 编辑 Rc 复制 QNS 170815 奥迪 A3 红色 一 汽 奥迪 2017-09-09 130000 FFE 
D JRE p 夏 制 @ 删除 110915 AASTA BB ”一 汽 大 众 2017-10-11 89400 FEBE 
D GP 编辑 xc 夏 制 Q MS 171014 奥迪 A4L 黑色 一 汽 奥迪 2017-11-11 184300 中 型 车 











18-23 ”完成 记录 添加 






B SA co 权限 P 操作 


汽车 编号 char (10) H [011 | 








汽车 型 号 char (10) | "ox | 


— Ji bai'se| Q IBWGS 











EADE den L—— —À1 Bine seme. 5 i 
WIDE date B |2017.0101 | 图 
ne man | ~| E [177800 | 

















18-24 ”修改 记录 











UPDATE “earsinfo SET KB, - “白色 ”WHERE “carsinfo .汽车 编号 ”= “170111” 








18-25 ”修改 记录 的 SQL 语句 

















及 结构 E soi à 搜索 O m E S G SA f Bf 号 权限 d ER 更 多 
um dm S BB og Am GRAM Ah RAO 
B business yk E 浏览 级 结构 ow 搜索 g € 3-9 0 InnoDB gb2312 chinese ci 16 KB - 
O earsinfo jy O HA je 418 a E* x HO T Qu 14 InnoDB gb2312 chinese ci 16 KP E 
Ø cars sales s E 浏览 g& 结构 EE RS HO € 青空 @ 刚 除 1 InnoDB £b2312 chinese ci 16 KB * 
O customer $ 浏览 e 结构 a 搜索 xc 插入 (m H QM 11 InnoDB $2312 chinese ci 16B E 
(J employee jk E HA yan & EF gii gs Qs 13 InnoDB gb2312 chinese ci 16 KB - 
|) user d: OHA e dida o. EE xd ge s QN 1 InnoDB b2312 chinese ci 16 KB = 
63k Sito 40 InnoDB zb2312 chinese ci 96 KB 0 字 节 


























1826 ”创建 完成 其 他 表 


© 创建 外 键 约束 。 浏 览 表 business, 单 击 “ 结 构 ” 超 链接 ,再 单 击 “ 关 联 视图 ”, 在 此 页 
面 中 输入 外 键 名 fk_emp, 添 加 “员工 编号 ”字段 ,按照 图 18-27 所 示 的 内 容 选择 数据 库 
carsales_info、 表 employee、 字 段 “ 员 工 编 号 ”, 并 选择 ON DELETE 和 ON UPDATE 后 的 选 


项 为 RESTRICT。 单 击 页 面 下方 的 “保存 ”按钮 即 可 。 





Ej xm» sa E SQL 3 搜索 X: WA g Sh B SA c5 权限 A 操作 c arz 
您 的 SQL 语句 已 成 功 运行 


ALTER TABLE "business! ADD CONSTRAINT fk esp FOREIGN KEY (员工 编号 ) REFERENCES "employee [员工 编号 ) ON DELETE RESTRICT ON UPDATE RESTRICT; 


y kän da 关联 视图 


CRRAR] [ 编辑 ] [ GR PHP 代码 ] 





—]| Foreign key constraints | 


Actions Constraint properties 字段 9 外 键 约束 (INNODB) 
aue FR 


[kemp 


AIRS "| [camales io | | employee ，| [AIRS 
+ Add column 


@ MF ow DELETE RESTRICT M 





ON UPDATE | RESTRICT t. 


图 18-27 创建 外 键 


H 





外 键 约束 创建 后 ,设计 器 中 的 business 和 表 employee 也 会 自动 连 线 , 如 图 18-28 


所 示 o 






a 搜索 o 查询 g 号 出 B SA 
























: char (10) 

: char (10) 
m 联系 时 间 : datetime 
日 联系 方式 : char(20) 
O 联系 结果 : char(50) 


è 员工 编号 char(10) 
O M : char(10) 
o 性 别 : char (4) 
& 年 龄 : int (11) 
a ÆR : char (30) 
: char (10) 













图 18-28 数据 库 的 设计 器 


© 修改 表 结 构 。 数 据 表 被 创建 后 ,可 以 在 图 18-26 所 示 的 数据 表 结构 页 面 中 修改 表 结 
Tg ,可 以 执行 添加 \ 删 除 、 修 改 字段 的 数据 类 型 或 者 字段 的 长 度 / 值 等 操作 。 也 可 以 创建 、 修 


改 索引 字段 。 


例如 , 单 击 表 employee 的 “结构 ” 超 链 接 , 进 入 如 图 18-29 所 示 的 修改 表 结 构 的 对 话 框 。 
单 击 “员工 编号 ?字段 行 的 “修改 "按钮 ,在 弹出 的 对 话 框 中 将 字段 长 度 20 修改 为 10, 单 击 
“预览 SQL 语句 ?按钮 ,如 图 18-30 Bron , 单 击 “关闭 ?按钮 之 后 ,再 单 击 “保存 ?按钮 , 即 可 完 


成 数据 表 的 结构 的 修改 。 


CD 删除 数据 表 。 要 删除 某 个 数据 表 , 首 先 选择 数据 库 , 在 图 18-26 所 示 的 数据 库 中 选 
择 数 据 表 , 单 击 “ 删 除 ” 按 钮 ,然后 在 弹出 的 对 话 框 中 单 击 “ 确 定 ” 按 钮 即 可 成 功 删除 指定 的 数 


据 表 。 


EDE 


^ 
"7 


Y 
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H 表 结构 d 关联 视图 





— M 类 型 ”排序 规则 Et 3 RU 注释 SOR 操作 ee 
C 1 AIRS P char(20) gb2312 chinese ci Sx J € @ 刚 除 P 主键 国 叭 一 二 索引 
口 2 *&& char (10) gb2312_chinese_ci 是 ML J 修改 @ WI 5 xy 唯一 园 索引 
B 3 性 别 char (4) gb2312_chinese_ci £N J € @ Ws.» xs E—g 索引 
O 4 FR int(1) 是 ML J Ek QN o Rye- aE 
G 5 #2 char (30) gb2312 chinese ci RON J €» Q WS e xs gpu— (E 索引 
O 6 学 历 char(10) gb2312 chinese ci 是 REF £P 修改 QW p Ryt- E 索引 


t. Dt sem ps 6x OMR Diu mE- EF 











[By 打印 makan dp Jo 移动 字段 A Improve table structure 


18-29 ”修改 表 结 构 











ALTER TABLE employee CHANGE “员工 编号 ”员工 编号 ”CHAR (10) CHARACTER SET 
本 2312 NL: 











图 18-30 ”修改 数据 表 结 构 
(3) 利用 SQL 语句 管理 数据 记录 。 在 phpMyAdmin 主 界面 中 选择 一 个 数据 表 


carsinfo , 单 击 “SQL” 超 链接 ,可 以 打开 SQL 语句 编辑 区 。 在 编辑 区 输入 完整 的 SQL 语句 ， 
来 实现 数据 的 查询 、 添 加 、 修 改 和 删除 操作 ,如 图 18-31 所 示 。 

















pe scalhost ”者 m ES 
E 浏览 H 结构 D SQL 9 SE EMM B 导出 B SA vE 
C Run SQL query/queries on table carsales_info. carsinfo: 图 m 
1 SELECT * FRON “earsinfo WHERE | AERE n 
汽车 型 号 
颜色 
生产 厂家 
出 厂 日 期 
价格 
汽车 类 型 
(SELECT*) (SELECT) (INSERT) (UPDATE) . 
<< 
(DELETE) (清除 | (格式 ) (Getauto-saved query ) verd 




















18-31 利用 SQL 语句 管理 表 数 据 


(D 使 用 SQL 语句 插入 数据 。 在 SQL 语句 编辑 区 应 用 insert 语句 向 数据 表 carsinfo 中 
插入 数据 后 ,如 图 18-32 所 示 。 单 击 “ 执 行 ” 按 钮 ,向 数据 表 中 插入 2 条 数据 ,如 图 18-33 所 
示 。 如 果 提 交 的 SQL 语句 有 错误 ,系统 会 给 出 一 个 警告 ,提示 用 户 进行 修改 。 





EXTET 
E] 浏览 xe 结构 E] sa 


也 搜索 X 插入 g 导出 图 SA c 


二 Run SQL query/queries on table carsales info.carsinfo: 图 和 一 一 


1 insert into cersinfo values( ^ ITOLIT', “标致 08”,“ 档 红色 "，’ 东 网 汽 车 '，“2017- 
78800, i 








uas( “170515' ,大 众 POL0' ，' EE, ESAR, 2017-08- 








(SELECT +) SELECT | | INSERT ， | UPDATE DELETE | 清除， 





(格式 ) (Get auto-saved query 








LJ Bind parameters @ 





图 18-32 ”使 用 SQL 语句 向 数据 表 中 插入 数据 








Ej M X Hh 回 sr A BR E OMA Zo Wh B OSA c RR v 更 多 
sizaa 

(Ov HAT 1! 行 。 GEATA 0.0600 We) 
insert into carsinfo values( '170117' ，* 标致 806' ,楼 红 色 ' ,东风 汽车 '，' 2017-06-01' ，176800,“ 小 型 车 ' ) 

URGE] CARI C ONR PHP (6 ] 





| ww 插入 了 1 行 。 (查询 花费 0.0480 We) 
insert into carsinfo values('1TOSIS', ‘KAP, ‘EE, ESAR, ‘2017-08-11, 53900, EE’ ) 
REME] [ 编辑 ] [ 创建 PHP 代码 ] 











18-33 插入 数据 成 功 


说 明 : 还 可 以 利用 其 右 侧 的 属性 列表 来 选择 要 操作 的 列 , 只 要 选中 要 添加 的 列 , 双 击 其 
选项 或 者 单 击 “<<” 按 钮 添加 列 名 称 。 

© 使 用 SQL 请 句 修改 数据 。 在 SQL 语句 编辑 区 应 用 update 语句 修改 数据 信息 ,将 汽 
车 编号 为 170117 的 汽车 型 号 改 为 “标致 708” ,颜色 为 金色 ,添加 的 SQL 语句 如 图 18-34 所 
示 。 单 击 “ 执 行 ”按钮 ,数据 修改 成 功 。 





B 浏览 M sa O SQL 9 搜索 X WA g SS 加 





~ Run SQL query/queries on table carsales info.carsinfo: 图 H 








1 WPDATE carsinfo SET 汽车 型 号 = its, HE - RES WERE 汽车 编号 
= 170117 
(SELECT*) (SELECT) (INSERT) (UPDATE) (DELETE) 











18-34 使 用 SQL 语句 向 数据 表 中 修改 数据 


O 使 用 SQL 语句 查询 数据 。 在 SQL 语句 编辑 区 应 用 select 语句 检索 指定 条 件 的 数据 
信息 ,将 汽车 编号 前 4 位 为 1701 的 数据 全 部 显示 出 来 ,添加 的 SQL 语句 如 图 18-35 所 示 。 
单 击 “ 执 行 ”按钮 ,该 语句 的 实现 结果 如 图 18-36 所 示 。 


Yyy 





MySQL 4t 46 Æ 85 3: 4e d 9-5 XE E 


MySQL 4t 4E E E JH 5 7E A LEE 5 EU 








E] 浏览 wx 结构 L| se X £t X AA Loss B 


r4 Run SQL query/queries on table carsales info.carsinfo: @ H 


1 SELECT * FRON cersinfo WHERE 汽车 编号 like “1701%| 





E 
| SELECT * | | SELECT | (INSERT) (UPDATE) DELETE | 

















18-35 ”添加 查询 数据 信息 的 SQL 语句 


E] 浏览 Y 结构 Eso A 搜索 X WA B St (d SA s 权限 Bf 
(ow 正在 显示 第 0-16 Gt 2 f, HITA 0.0000 We) 


SELECT * FRON cersinfo WHERE 汽车 编号 like “1701% 


C) 性 能 分 析 DRE [ 编辑 ] [ 解析 SQL ] [ 创建 PHP 代码 ] 


BO 显示 全 部 | fa: | 25 v) wem [cakes 按 索引 排序 | 无 " 
+ 选项 

T> 0 v 汽车 编号 AHE Be FF HAM fi AFAM 

D J'R xc 复制 Q WR 170111 标致 白色 ”东风 汽车 2017-01-01 177800 小 型 车 


O s? 编辑 xc EH Q NR 170117 标致 708 ”金色 ”东风 汽车 2017-06-01 178800 ”小 型 车 








t. OG 全 选 4e. IR KEN QUI GSi 


18-36 查询 指定 条 件 的 数据 信息 





说 明 : 此 SQL 编辑 区 可 以 进行 整个 表 的 简单 查询 外 ,还 可 以 执行 复杂 的 条 件 查询 ,如 
IŁ M where F 4) 3t X like,order by、group by 等 条 件 查询 子 句 。 也 可 以 进行 多 表 连 接 查 询 、 
子 查询 等 。 

CD 使 用 SQL 语句 删除 数据 。 在 SQL 语句 编辑 区 应 用 delete 语句 检索 指定 条 件 的 数 
据 或 全 部 数据 信息 ,删除 名 称 为 “ 计 非 竹 ” 的 员工 信息 ,添加 的 SQL 语句 如 图 18-37 所 示 。 








H Run SQL query/queries on table carsales info.employee: @ 




















1 DELETE FROM "employee" MERE “姓名 = 计 非 竹 ; 








(SELECT*) (SELECT) (INSERT) (UPDATE) (DELETE) 











E 18-37 删除 指定 数据 信息 的 SQL 语句 


单 击 “ 执 行 " 按 钮 ,弹出 确认 删除 操作 对 话 框 , 单 击 “ 确 定 ” 按 钮 ,执行 数据 表 中 指定 条 件 
的 删除 操作 。 如 果 delete 语句 后 面 没 有 where 条 件 值 ,那么 将 删除 指定 数据 表 中 的 全 部 
数据 。 

(4) 搜索 数据 。 选 择 某 个 数据 表 后 , 单 击 “ 搜 索 ” 超 链接 ,进入 搜索 页 面 。 在 这 个 页 面 
中 ,可 以 在 选择 字段 的 列表 框 中 指定 搜索 条 件 , 如 图 18-38 所 示 , 可 以 对 表 carsinfo 的 记录 
按 条 件 进 行 查询 。 选 择 查 询 的 条 件 后 , 单 击 “ 执 行 ”按钮 即 可 。 

(5) 数据 的 导入 导出 。 使 用 phpMyAdmin 软件 导入 导出 数据 ,可 以 实现 对 数据 库 的 结 
构 和 数据 的 导入 导出 ,包括 导入 导出 多 种 格式 的 文件 ,本 质 上 这 是 一 种 转换 数据 格式 的 复 





Ej 浏览 x sa H soi A 搜索 *X 插入 B Si d SA c BR ^ Rf c urz 


4 SAER $ Zoom search Z TÄNA 
































字段 AM 排序 规则 ENE ë ë hd - 
汽车 编号 char (10) gb2312 chinese ci — LIKE . 709€ 

汽车 型 号 char (10) gb2312 chinese ci — LIKE D | 

me char(10) gb2312 chimese ci UKE M 

生产 厂家 char (30) gb2312 chinese ci UKE M I 

出 厂 日 期 date > v] [2016-09-01 | 
价格 ánt (11) > | [150000 — 

















18-38 ”搜索 查询 


制 。 导 入 导出 可 以 是 在 数据 库 和 表 两 种 模式 下 进行 ,操作 过 程 和 步骤 相近 。 

O 导出 数据 表 的 结构 和 数据 。 选 择 数据 表 carsinfo, 单 击 页 面 中 的 “导出 ” 超 链 接 , 打 开 
导出 编辑 区 。 从 下 拉 框 中 选择 导出 文件 的 格式 ,默认 使 用 选项 *SQL”。 如 图 18-39 所 示 ,这 
里 使 用 选项 “CSV for MS Excel”, 单 击 “ 执 行 ” 按 钮 ,弹出 如 图 18-40 所 示 的 文件 下 载 对 话 
框 , 单 击 “ 下 载 " 按 钮 ,将 数据 文件 以 “. csv” 格 式 存 储 在 指定 位 置 。 





园 浏 览 H 结构 O SQL 9 搜 索 X WA 局 Sk d SA co 权限  &Rf 


正在 导出 数据 表 “carsinfo” 中 的 记录 


导出 方式 : 
e 快速 ~- 显示 最 少 的 选项 
© BEX - 显示 所 有 可 用 的 选项 





格式 : 





CSV for MS Excel 


执行 








图 18-39 导出 MySQL 表 的 设置 界面 





新 建 下 载 任务 x 





BU: | http://localhost81/phpmyadmin/export.php 





名 称 : carsinfo .csv 1KB 


CREER]: |CAUsersVAdministratoiDesktop — 48.04 GB » || S 











图 18-40 存储 MySQL 数据 的 对 话 框 
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© 导入 MySQL 数据 库 脚 本 。 单 击 * 导 入 ” 超 链 接 , 进 入 执行 MySQL 数据 库 的 脚本 界 

面 , 单 击 “ 选 择 文件 ”按钮 查找 脚本 文件 (如 carsinfol. csv) 所 在 位 置 , 如 图 18-41 所 示 , 单 击 

“执行 ?按钮 , 即 可 执行 导入 MySQL 数据 库 脚本 文件 。 导 入 的 表 的 名 称 为 table7 ,如 图 18-42 所 
示 。 此 时 可 以 浏览 table7 数据 ,也 可 以 修改 表 名 。 

IESS: 


y 结构 Lj sa A 搜索 回 m E Sh 图 SA Bf 





导入 到 数据 库 “carsales_info” 


要 导入 的 文件 : 


文件 可 能 已 压缩 (ezip, zip) 或 未 压缩 。 
压缩 文件 名 必须 以 . [格式 ] . [压缩 方式 ] 结尾。 如 : - sql. zip 





从 计算 机 中 上 传 : 【选择 文件 | carsinfot.csv (最 大 限制 : 2, 048 KB) 
您 可 在 各 页 面 间 拖 放 文件 。 
文件 的 字符 集 : | utf8 M 








图 18-41 执行 MySQL 数据 库 脚本 文件 





I4 结构 E so a 搜索 O SB 加 号 出 SA 0 Bf co 权限 d) ER OO Wf v 更 多 
S IARD, NET 2 TEN. 
下 列 结构 被 创建 或 修改 。 你 可 以 : 

。 请 通过 点 击 结构 的 名 称 末 坦 看 它 的 内 座 。 


。 点 击 相应 的 “选项 ”链接 修改 设置 。 
。 请 通过 点 击 “ 结 构 ” 链接 来 编辑 结构 - 


* carsales info (选项 ) 
e TABLE T d (选项 ) 
(carsinfo .cev) 
^ MySQL 返回 的 查询 结果 为 空 〈 即 零 行 )。 (WATR 0.1860 W) 
CREATE TABLE IF NOT EXISTS carsales info TAÐLE 7 (COL 1 varchar(49)) DEFAULT CHARACTER SET utfO COLLATE ut66_general_ecii 


GRIPI] [ 编辑 ] [ 创建 PHP 代码 ] 





y 插入 了 17 行 。 (查询 花费 0.0520 秒 。) 








图 18-42 成 功 执行 导入 操作 


(6) 数据 库 的 用 户 和 权限 管理 。 在 phpMyAdmin 图 形 化 管理 工具 中 ,不 但 可 以 对 
MySQL 数据 库 进行 各 种 操作 ,而 且 可 以 添加 服务 器 的 新 用 户 , 并 对 新 旧 用 户 设置 权限 。 

(D 添加 MySQL 服务 器 新 用 户 。 单 击 phpMyAdmin 主 界面 中 的 “账户 ” 超 链 接 , 打 开 服 
务 器 用 户 操作 界面 ,如 图 18-43 所 示 。 

在 该 页 面 中 , 单 击 “ 新 增 用 户 账户 ”。 进 入 如 图 18-44 所 示 的 界面 ,设置 用 户 名 、 密 码 E 
机 ,并 对 新 用 户 的 权限 进行 设置 。 设 置 完成 后 , 单 击 * 执 行 ? 按 钮 ,完成 对 新 用 户 的 添加 操作 ， 
返回 主页 面 , 将 提示 新 用 户 添 加 成 功 ,如 图 18-45 所 示 。 

@ 重 置 用 户 登录 密码 。 在 phpMyAdmin 图 形 化 管理 工具 中 ,不 但 可 以 对 MySQL 数据 
库 进行 各 种 操作 ,而 且 可 以 对 用 户 的 权限 进行 重新 设置 .同时 还 可 以 对 MySQL 服务 器 的 登 
录 密 码 进行 重 置 。 单 击 图 18-45 中 的 “修改 密码 ”按钮 ,打开 服务 器 用 户 操 作 界面 ,可 以 在 此 
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O Pool localhost 是 WSAGE € £ 修改 权限 LS 
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Lj swing localhost 是 USAGE & & 修改 权限 图 号 出 
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18-43 ”服务 器 用 户 一 览 表 





回 awe Lj SQL & wt 


| 登录 信息 上 


User name: 


PRIM 
Host name: 
本 地 
EA: [REXEN 
重新 输入 : 
Authentication 
Plugin 
ERED LL 





= se 加 导出 B SA A 设置 B 二 进 制 日 志 | 复制 v ES 
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18-44 设置 添加 用 户 信息 











i SEE O SQL d us 


v 您 已 添加 了 一 个 新 用 户 。 


CREATE USER “rose’@ localhost’ IDENTIFIED WITH sysql native password AS “zi ;GRANT SELECT ON s.* TO "rose @ localhost’ REQUIRE NONE YITH 
MAX QUERIES PER HOUR O MAX CONNECTIONS PER HOUR O MAX UPDATES FER HOUR O MAX VSER CONNECTIONS 0; 


Global “数据库 BREA ”登录 信息 


修改 权限 : ”用户 账户 “rose”"@' localhost’ 


= KP J SS B SA A 设置 B 二 进 制 日 志 | RA v 更 多 


Dex] [ 编辑 ] [ 创建 FHP 代码 ] 

















图 18-45 ”成 功 添加 用 户 信息 
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重新 设置 密码 ,还 可 以 单 击 “ 生 成 ”按钮 ,由 系统 生成 密码 ,如 图 18-46 所 示 。 
修改 和 权限: ”用户 帐户 "Rose'€ localhost” 








f J! 
EREA | 
Oo ZER 


2 sch: NN Strone 





密码 加 密 方式 : | Native MySQL authentication M 


生成 密码 储 殉 |pumdzEkuyowrez — | 








图 18-46 ”修改 用 户 密码 


C) 修改 用 户 权 限 。 在 图 18-43 所 示 的 页 面 中 ,可 以 对 指定 用 户 的 权限 进行 编辑 、 可 以 
添加 新 用 户 和 删除 指定 的 用 户 。 这 里 选择 指定 的 用 户 , 单 击 “ 修 改 权 限 ” 超 链接 ,对 指定 用 户 
的 权限 进行 设置 ,如 图 18-47 所 示 。 在 此 可 以 设置 用 户 的 权限 后 , 单 击 “ 执 行 " 按 钮 ,完成 对 
用 户 权限 的 修改 操作 ,返回 主页 面 。 


EARR: APEP Rose @ localhost 








d 全 局 权限 c 2a] 


Note: MySQL privilege names are expressed in English 


LE s 管理 
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18-47 ”修改 用 户 权 限 


(7) 存储 过 程 的 基本 操作 。 存 储 过 程 是 MySQL 中 常用 的 数据 库 对 象 , 在 
phpMyAdmin 图 形 化 管理 工具 中 存储 函数 、 触 发 器 和 事件 等 数据 库 对 象 的 操作 过 程 与 此 
类 似 。 

CO 创建 存储 过 程 。 选 择 数 据 库 carsales_info. 单 击 phpMyAdmin 页 面 中 的 “程序 ” 超 链 
接 , 在 “新 建 ? 区 域内 单 击 “ 添 加 程序 ?按钮 ,进入 程序 编辑 页 面 ,输入 程序 名 称 select_cars, 选 
择 程序 类 型 为 PROCEDURE, 设 置 参数 (也 可 以 删除 参数 设置 创建 无 参 过 程 ) ,在 文本 编辑 
区 输入 文本 ,如 图 18-48 所 示 。 

© 生成 存储 过 程 。 在 图 18-48 中 单 击 “ 执 行 ”按钮 ,系统 就 创建 一 个 存储 过 程 select_ 
cars, 如 图 18-49 所 示 , 如 果 有 错误 ,系统 会 提示 .可 以 根据 提示 进行 修改 。 

© 执行 存储 过 程 。 单 击 图 18-49 中 存储 过 程 select cars 行 的 “执行 ”按钮 ,系统 就 会 运 
行 此 存储 过 程 ,执行 结果 如 图 18-50 所 示 。 


























Hwa | 
程序 名 称 [select cars ] 
xm | PROCEDURE "| 
参数 方向 名 字 类 型 长 度 / 什 选项 
G mes Jl 





where 汽车 编号 like "1719: 





AB; xm 





1848 创建 存储 过 程 





Sineo where APRE Iik 


w^ 已 创建 程序 select cars 。 


"select. E 0 NT 


DETERMINISTIC NO SQL SQL SECURITY DEFINER begin select * from 








IY ; end ; 
GREMI [ 编辑 ] [ 创建 PHP 代码 ] 
| 程序 o 2 
名 字 操作 类 型 — 返回 


上 select cars 7 编辑 p 执行 E 导出 @ 删除 PROCEDURE 


























18-49 创建 存储 过 程 成 功 





w^ 您 的 SQL 语句 已 成 功 运行 。 
5 rows affected by the last statement inside the procedure. 





CALL select cars 0; 


(—| EÈ “select_cars” 的 运行 结果 | 





171385 
171416 








汽车 编号 汽车 型 号 颜色 生产 厂家 出 三 日 期 ”价格 ”汽车 类 型 
171014 ”奥迪 A4L 黑色 一 汽 奥迪 2017-11-11 184300 中 型 车 
171112 ”新 蒙迪欧 银 砂 灰色 长 安福 特 2016-11-01 159700 中 型 车 
171213 MHR 星际 基色 一 汽 马自达 2016-12-21 161800 中 型 车 


进口 奥迪 A8L 旋风 黑色 奥迪 汽车 公司 2017-11-27 566300 豪华 型 车 


宝马 730LI 


宝石 青色 宝马 汽车 公司 2017-04-16 650000 豪华 型 车 





(8) 二 进 制 日 志 


18-00 存储 过 程 的 运行 结果 


的 管理 。 在 phpMyAdmin 的 主页 面 中 , 单 击 “ 二 进 制 日 志 ” 超 链接 ,可 


以 查看 当前 MySQL 数据 库 中 的 二 进 制 日 志 。 在 “选择 要 查看 的 二 进 制 日 志 ” 标 签 的 下 拉 框 
中 选择 二 进 制 日 志文 件 , 如 图 18-51 所 示 。 单 击 “ 执 行 ” 按 钮 ,系统 会 显示 此 文件 中 的 二 进 制 
事件 表 , 如 图 18-52 所 示 。 如 果 选 择 “ 性 能 分 析 ”, 系统 会 自动 显示 系统 详细 的 状态 描述 文件 
如 图 18-53 所 示 。 通 过 这 些 方 法 ,可 以 对 MySQL 服务 器 的 运行 状态 进行 检测 和 观察 ,以 进 


一 步 优 化 服务 器 的 管理 。 
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(3 SHE G soL (d db = sA E Si B OSA A aa [D 二 进 制 日 志 v 更 多 





ri 选择 要 查看 的 二 进 制 日 志 F 


PGIG1MIWMYPOFBS:-bin.000065 (17.16 KB) v | 11 Xf, 31,081 


PGIG1MIWMYPOFBS-bin.000056 (541 2753) 
PGIG1MIWMYPOFBS-bin.000057 (177 x5) 
PGIG1MIWMYPOFBS-bin.000058 (154 2-33) 
PGIG1MIWMYPOFBS-bin.000059 (177 2-55) | 执行， 
PGIG1MIWMYPOFBS-bin.000060 (177 字 节 ) 
PGIG1MIWMYPOFBS-bin.000061 (177 字 节 ) 
PGIG1MIWMYPOFBS-bin.000062 (177 字 节 ) 
PGIG1MIWMYPOFBS-bin.000063 (177 字 节 ) | 
PGIG1MIWMYPOFBS-bin.000064 (177 字 节 ) 
PGIG1MIWMYPOFBS-bin.00006: 

PGIG1MIWMYPOFBS-bin.000066 (11.31 KB) 





Ei 
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0, 25 


O 性 能 分 析 [编辑 内 该 ] [ 编辑 ] [ 创建 PHP 代码 ] [BA] 














18-51 选择 二 进 制 日 志文 件 





w^ 您 的 SQL 语句 已 成 功 运行 * 


SHON BINLOG EVENTS IN 'PGIGIMIWMYPOPBS-bin.000065' LIMIT 0，25 


C) 性 能 分 析 DRE] [ 编辑 ] [ 创建 PHP 代码 ] [ 刷新 ] 





bE 4 Format desc 1 123 Server ver: 5.7 1T-log, Binlog ver: 4 


|PGIGIMIWIYPOFBS- 123 
|bin. 000065. 


PG IG1MIWMYPOFBS- 
bin. 000065 


Previous gtids — 1 — 154 
154 Anonymous Gtid 1 219 SET 8@8SESSION GTID_NEXT= “ ANONYMOUS” 


|PGIG 1MIWMYPOFBS— 
|bin. 000065 





CREATE DATABASE carsales_info DEFAULT CHARSET=gb2312 
219 Query 1 391 2i chinese, ci 











18-92 查看 二 进 制 日 志文 件 内 容 





| 性 能 分 析 上 





Detailed profile Summary by state 
Ordera State HH, State@ Total Time X Time Calls æ Time 

1 Starting 196 us Starting 196 us 17.17% 1 196 us 
2 Query End 3 us Freeing Itens 4i hs 16. 14% E 4i us 
3 Closing Tables 2 us Cleaning Up 12 us 4. T2. 1 12 us 
4 Freeing Items 41 us Query End 3us 1.18% 1 3 bs 
5 Cleaning Up 12 us Closing Tables 2 us 0.79% 1 2 us 





Starting 画 Query End 
i| Closing Tables [i] Freeing Items 
画 Cleaning Up 














图 18-53 查看 服务 器 性 能 指标 


phpMyAdmin 软件 功能 强大 ,一 般 情况 下 ,能 够 实现 MySQL 数据 库 管理 的 常用 操作 ， 
在 学 习 过 程 中 ,可 以 举一反三 ,尝试 着 去 完成 一 些 其 他 操作 。 同 时 ,也 可 以 采用 可 视 化 方法 
观察 MySQL 数据 库 服务 器 性 能 的 指标 参数 ,例如 系统 变量 、 字 符 集 、 插 件 、 存 储 引 擎 、 服 务 
器 运行 状态 等 。 还 可 以 实现 设置 编码 格式 ,创建 PHP 代码 等 操作 。 

4. 实验 报告 总 结 

(1) 总 结 phpMyAdmin 软件 操作 过 程 中 常常 出 错 的 原因 。 

(2) 总 结 phpMyAdmin 软件 与 其 他 可 视 化 软件 相 比 ,展现 的 些 优势 。 

Wi. carsales info 数据 库 的 表 结 构 和 常用 数据 。 


# 数 据 库 -汽车 销售 信息 管理 系统 
create database carsales info; 
use carsales info; 
LIE UE 
create table user( 
userId char(10) primary key, 
username char(20), 
password char(10) 
insert into user values('111111', 'admin', 'admin'); 
# 汽 车 信息 表 
create table carsinfo( 
汽车 编号 char(10) primary key, 
汽车 型 号 char(10), 
颜色 char(10), 
生产 厂家 char(30), 
出 厂 日 期 date, 
价格 int, 
汽车 类 型 char(20) 
); 
insert into carsinfo values( 
型 车 ' ); 
insert into carsinfo values( 
微型 车 ' ) ; 
insert into carsinfo values( 
车 '); 
insert into carsinfo values( 
' 小 型 车 '); 
insert into carsinfo values( 
' 小 型 车 '); 
insert into carsinfo values( 
insert into carsinfo values( 
21',，73900，' 紧 凑 型 车 ' ); 


insert into carsinfo values( 


'"170111'，' 标 致 '，' 蓝 色 '，' 东 风 汽 车 '，'2017 - 01 -01', 177800,' 小 
'170212',，' 吉 利 熊猫 '，' 白 色 '，' 吉 利 汽车 ','2017 -02 一 11', 29700, ' 
'170314'，' 奔 奔 '，' 白 色 '，' 长 安 轿车 '，'2017 - 02 -11',，34400,' 微 型 
"170415'，' 大 众 POLO'，' 绿 色 '，' 上 海 大 众 "'，'2017 - 03 - 11', 53900, 
"170516'"，' 新 威驰 '，' 蓝 色 '，' 一 汽 丰田 '"，'2016 - 10 - 01', 49800, 


"1750623'，'MG3'，' 红 色 '，'MG'，'2017- 11- 01', 45700, "HEISE ); 
"170715'，' 科 和 鲁 兹 三 厢 '，' 白 色 '，' 上 汽 通 用 雪佛兰 '2017- 08 - 


'170815'，' 奥 迪 MN3'，' 红 色 '，' 一 汽 奥迪 '，'2017 - 09 - 09", 130000, " 


紧凑 型 车 ' ); 

insert into carsinfo values( '170915'，' 大 众 高 尔 夫 '，' 白 色 '，' 一 汽 大 众 , '2017 - 10- 11', 89400, 
"紧凑 型 车 ' ); 

insert into carsinfo values( '171014'，' 奥 迪 ML'，' 黑 色 '，' 一 汽 奥 迪 '"，'2017- 11- 11', 184300, 
"中 型 车 ' ); 


insert into carsinfo values( 


"171112"，' 新 蒙迪欧 '，"' 银 砂 灰色 '，"' 长 安福 特 '，'2016- 11- 01', 
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159700, "pP E); 
insert into carsinfo values( '171213'，' 阿 特效 '，' 星 际 蓝 色 '，' 一 汽 马 自 达 '，'2016- 12-7 21', 
161800，' 中 型 车 ' ); 
insert into carsinfo values( '171385'，' 进 口 奥迪 A8L'，' 旋 风 黑 色 '，' 奥 迪 汽 车 公司 '，'2017 -11 
27'，566300，' 豪 华 型 车 ' ); 
insert into carsinfo values( '171416'，' 宝 马 730Li'，' 宝 石 青 色 '，' 宝 马 汽车 公司 "'，'2017- 04 - 16 
', 650000，' 豪 华 型 车 ' ); 
# 职 工 表 
create table employee( 
员工 编号 char(20) primary key, 
姓名 char(10), 
性 别 char(4), 
4E int, 
籍贯 char(30), 
学 历 char(10) 
) 
insert into employee values( 'e201701', ' 余 凯 富 ', ' 男 ', 22, ' 山 东 青岛 ',' 本 科 '); 
insert into employee values( 'e201702', ' 任 至 至 ', ' 女 ',21, ' 北 京 朝阳 ', ' 大 专 '); 
insert into employee values( 'e201703', ' 岳 灵 珊 ', ' 女 ',21, ' 上 海 虹口 ', BE); 
insert into employee values( 'e201704', ' 林 丽 芬 ', ' 男 ', 23, ' 河 北 廊坊 ', ' 博 士 '); 
insert into employee values( 'e201705', ' 岳 秋 萍 ', ' 男 ', 30, "北京 海淀 ', ' 博 士 '); 
insert into employee values( 'e201706', ' 仪 项 琳 ', ' 女 ',28, "西藏 拉萨 ', AS RE); 
insert into employee values( 'e201707', ' 林 南 理 ', ' 男 ', 32, ' 山 西 运 城 ', ' 硕 士 '); 
insert into employee values( 'e201708', ' 左 宗 海 ', ' 男 ', 35, ' 湖 南 长 沙 ', ' 本 科 '); 
insert into employee values( 'e201709', ' 向 四 伏 ', ' 男 ', 33, ' 海 南 三 亚 ', ' 专 科 '); 
insert into employee values( 'e201710', ' 田 回 光 ', ' 男 ', 40, ' 浙 江 杭 州 ', "高 中 '); 
insert into employee values( 'e201711',，' 王 子 虚 ', ' 男 ', 36, ' 山 西 大 同 ', ' 初 中 '); 
insert into employee values( 'e201712', ' 段 开设 ', ' 男 ', 24, ' 陕 西西 安 ', ER); 
insert into employee values( 'e201713', ' 计 非 竹 ', ' 男 ',23, "四川 成 都 ', ' 小 学 '); 
# 客 户 表 
create table customer( 
客户 编号 char(10) primary key, 
客户 名 称 char(10), 





性 别 char(4), 
联系 方式 char(12)， 
地 址 char(30) 


); 
insert into customer values( 'c201701', ' 李 洪 发 ', ' 男 ', '18712345678', ' 罚 山 '); 
insert into customer values('c201702', ' 赵 灵 王 ', ' 女 ', '18723456781', 'H IE); 
insert into customer values( 'c201703', ' 林 月 野 ', ' 女 ', 18734567812', ' 林 保 '); 
insert into customer values( 'c201704', ' 林 阿 风 ', ' 女 ', '18745678123', ' 南 寨 '); 
insert into customer values('c201705', ' 景 天 印 ', ' 男 ', '18756781234', ' 渝 州 '); 
insert into customer values( 'c201706', ' 唐 雪 因 ', ' 女 ', '18767812345', ' 渝 达 '); 
insert into customer values('c201707', 'JE /6 3€ ', ' 女 ', '18778123456', ' 台 湾 '); 
insert into customer values( 'c201708', 'fg I lll ', ' 男 ', 18781234567, 'B $ '); 
insert into customer values( 'c201709', ' 南 官 梅 ', ' 男 ', '18713456782', ' 洞 庭 '); 
insert into customer values('c201710', ' 姜 云 成 ', ' 男 ', '18714567823', ' 欧 河 '); 
insert into customer values('c201711', ' 唐 雨 白 ', ' 女 ', '18715678234', ' 青 镇 '); 

井 业务 表 

create table business( 

员工 编号 char(10), 











客户 编号 char(10), 
联系 时 间 datetime, 
联系 方式 char(20), 
联系 结果 char(50) 
) 
# 汽 车 销售 信息 表 
create table cars_sales( 
订单 编号 char(20) primary key, 
汽车 编号 char(10), 
销售 日 期 date, 
汽车 类 型 char(20), 
颜色 char(20), 
数量 int, 
销售 价格 int, 
员工 编号 char(10), 
客户 编号 char(10) 
) 
insert into cars sales values( 'sale001', '10101', '2017 - 09 -23', 'SUV', ' 黑 色 ', 10, 120000, ' 
007', '110' ); 
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第 3 部 分 
MySQL 数 据 库 模 拟 试题 及 参考 答案 





学 习 导 读 : 

本 部 分 包括 6 套 MySQL 数据 库 的 模拟 试题 和 参考 答案 ， 
涵盖 了 本 课程 的 主要 知识 点 ,可 以 帮助 读者 了 解 和 检验 自己 的 
学 习 情 况 。 

前 4 套 以 MySQL 基本 知识 和 基本 操作 为 重点 内 容 ,第 5 
套 有 个 别 题目 是 PHP 软件 内 容 , 第 6 套 添加 了 数据 库 设计 方面 
的 内 容 。 


MySQL 数据 库 模拟 试题 1 


说 明 : 本 试题 为 笔试 方式 ,考试 时 间 100 分 钟 ,总 计 100 分 。 
一 、 选 择 题 (每 题 1 分 , 共 20 分 ) 


1. 下 面 标识 符 不 合法 的 是 

A. null 1 B. mysql C. 3money D. triggerl 
2. MySQL 数据 库 无 处 不 在 的 数据 危险 不 包括 : 

A. 系统 故障 B. 计划 故障 C. 介质 故障 D. 事务 故障 
3. 使 用 select 将 表 中 数据 导出 到 文件 ,可 以 使 用 子 句 。 

A. to file B. into file C. out to file D. into outfile 
4. 一 个 关系 只 有 一 个 

A. 候选 码 B. 主 码 C. 外 码 D. 超 码 


5. 基于 “学 生 - 选 课 -课程 "数据库 中 的 3 个 关系 : 
stu(sno, sname, sex, department), 主 码 是 sno 
course(cno cname, teacher), 主 码 是 cno 
sc(Sno,cno,grade), 主 码 是 (sno, cno) 
在 下 列 关 于 保持 数据 库 完整 性 的 叙述 中 ， 是 不 正确 的 。 
A. 向 关系 sc 插入 元 组 时 ,sno 和 cno 都 不 能 是 空 值 (null) 
B. 可 以 任意 删除 关系 sc 中 的 元 组 
C. 向 任何 一 个 关系 插入 元 组 时 ,必须 保证 该 关系 主 码 值 的 唯一 性 
D. 可 以 任意 删除 关系 cno 中 的 元 组 


6. 要 想 移 除 账户 ,应 使 用 语句 。 

A. delete user B. drop user C. delete priv D. drop priv 
7. 触发 器 可 以 创建 在 中 。 

A. 表 B. 索引 C. 事件 D. 函数 
8. 使 用 语句 删除 触发 器 trig test. 


A. drop * from trig_Test 
B. drop trig_Tes 
C. drop triger where name= 'trig Test" 
D. drop triger trig Test 
9. 在 SQL 语言 中 , 子 查询 是 P 
A. 返回 单 表 中 数据 子 集 的 查询 语句 
B. 选取 多 表 中 字段 子 集 的 查询 语句 
C. 选取 单 表 中 字段 子 集 的 查询 语句 
D. 嵌入 到 另 一 个 查询 语句 之 中 的 查询 语句 
10. 在 数据 库 设 计 中 ,E-R 模型 是 进行 的 一 个 主要 工具 。 
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A. 需求 分 析 B. 概念 设计 C. 逻辑 设计 D. 物理 设计 
11. 通过 以 下 语句 临时 关闭 事件 e_test。 
A. alter event e test disable B. alter event e test drop 
C. alter event e test enable D. alter event e test delete 
12. 视图 是 一 个 虚 表 ,视图 的 构造 基于 
A. 基 表 或 视图 B. 基 表 或 索引 
C. 视图 或 索引 D. 基 表 、 视 图 或 索引 
13. 设 s_avg(sno,avg_grade) 是 一 个 基于 关系 sc 定义 的 学 号 和 他 的 平均 成 绩 的 视图 。 
下 面 对 该 视图 的 操作 语句 中 ， 是 不 能 正确 执行 的 。 





I. update s avg set avg_grade=90 where sno=2017010601 
Il. select sno. avg grade from s avg where sno— 2017010601 








A. I B. 4X Il C. 都 能 D. 都 不 能 
14. 如 果 关 系 模式 R 属于 1NF, 且 每 个 非 主 属性 都 完全 函数 依赖 于 R 的 主 码 , 则 R 属 
F 。 
A. 2NF B. 3NF C. BCNF D. 4NF 
15. 可 用 于 从 表 或 视图 中 检索 数据 的 MySQL 语句 是 
A. select B. insert C. update D. delete 
16. MySQL 安装 成 功 后 ,在 系统 中 会 默认 建立 一 个 用 户 。 
A. root B. user C. mysql D. sys 
17. 当 使 用 select 语句 返回 的 结果 集中 行 数 很 多 时 ,为 了 便于 用 户 对 结果 数据 的 浏览 
和 操作 ,可 以 使 用 子 句 来 限制 被 select 语句 返回 的 行 数 。 
A. limit 语句 B. insert 语句 C. update 语句 D. delete 语句 
18. delete from Stu where 4E ilit 60 语句 的 功能 是 A 


A. 从 Stu 表 中 彻底 删除 记录 
B. Stu 表 中 年 龄 大 于 60 岁 的 记录 被 删除 
C. 删除 Stu 表 
D. 删除 Stu 表 的 年 龄 列 
19. 索引 可 以 提高 哪 一 操作 的 效率 ? 











A. insert B. update C. delete D. select 
20. 在 MySQL 中 ,可 以 使 用 语句 删除 表 中 的 全 部 数据 而 保留 表 结 构 。 
A. limit B. outer C. drop D. truncate 
二 、 填空 题 (每 空 1 分 , 共 10 分 ) 
1. 在 ER 图 中 ,和 矩形 表示 :椭圆 形 表 示 " 
2. 保存 在 MySQL 安装 目录 中 的 选项 文件 名 是 o 
3. MySQL 安装 包含 典型 安装 .定制 安装 和 3 种 安装 类 型 。 
4. 如 果 一 个 列 是 类 型 , 则 可 以 使 用 关键 字 指 定 该 列 的 值 自动 增加 。 
5. 在 MySQL 中 ,通常 使 用 值 来 表示 一 个 列 是 未 确定 值 的 情形 。 
6. 将 一 个 列 设置 为 主键 的 方法 是 ,在 列 的 定义 中 使 用 38. 
7. 创建 普通 索引 时 ,通常 使 用 的 关键 字 是 


8. 如 果 使 用 关键 词 , 则 即使 在 更 新 过 程 中 出 现 错误 ,更 新 语句 也 不 会 中 断 。 
三 、 阅 读 程序 ,指出 下 列 程序 段 的 功能 (每 题 3 分 , 共 18 分 ) 
l. delimiter // 
create function count pro (sid int) returns int 
begin 
return (select count( * ) from arts where s id = sid); 
end // 
delimiter ; 
2. explain select * from fruits where f name like ' &x'; 
explain select * from fruits where f name like 'x 5 '; 
3. mysqldump -uroot -p  -- databases booksDB test > 
d:MbackupVbooks testDB 20170301.sql 


4. declare bookname char(50); 
declare bookprice decimal(8,2); 
select b name,b price into bookname, bookprice 
from books where b id = 'a1101'; 


5. create index index name on fruits(f name); 


explain select * from fruits where f name- 'apple'; 
6. declare id int default 0; 
add loop: loop 
set id = id + 1; 
if id»- 10 then leave add loop; 
end if; 
end loop add loop; 
、 简 答题 (每 小 题 3 分 , 共 12 分 ) 
1. 简 述 性 能 优化 的 目标 和 功能 。 
2. 简 述 共享 锁 与 排他 锁 的 作用 。 
3. 简 述 用 户 访问 MySQL 服务 器 数据 的 工作 流程 。 
4. 简 述 使 用 视图 的 优点 。 
五 、 综 合 题 (每 小 题 4 分 . 共 40 分 ) 
MA MySQL 数据 库 teach 中 的 3 个 表 , 表 结构 分 别 描述 如 下 : 
student( 学 号 char(9) primary key, 姓名 char(10), 住址 varchar(20), 性 别 char(2), 系 名 char(12)) 
course( 课 程 号 char(6) primary key, 课 程 名 char(12), 学 时 int, 教 师 编号 char(6)) 
c select (学 号 char(9), 课 程 号 char(6), 成 绩 int ) 
按 要 求 使 用 MySQL 语句 完成 操作 。 
1. 利用 Alter Table 命令 在 c_select 表 中 添加 主键 “学 号 十 课程 号 ”。 并 创建 外 键 
fk_1, 参 照 student 表 的 学 号 。 
2. 查询 姓名 为 “黄岩 ”的 学 生 所 选课 程 的 “课程 名 ”及 “成 绩 ”。 
3. 创建 视图 V_update, 检 索 所 有 选修 课程 号 为 c05126 的 学 生 的 学 号 .课程 号 及 成 绩 。 
4. 创建 存储 过 程 upcourse 修改 课程 名 称 . 提 示 输 入 参数 为 课程 号 ,输出 参数 为 旧 的 课 
程 名 称 与 新 的 课程 名 称 。 
5. 调用 存储 过 程 ,并 查看 课程 名 的 修改 情况 。 


Y gos 
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6. 添加 登录 名 为 tuser, 密 码 为 123abc 的 MySQL 登录 账户 。 用 户 tuser 对 当前 数据 库 
中 的 所 有 表 有 查询 、 插 和 人 权限 ,并 授予 grant 权限 。 

7. 使 用 revoke 语句 收回 tuser 用 户 的 所 有 权限 ,包括 grant 权限 。 

8. 使 用 mysqldump 命令 备份 数据 库 中 的 c_select 表 , 备 份 路 径 为 d:/bak/ ,备份 文件 
名 为 teach_cs. sql. 

9. 创建 一 个 after 触发 器 ,要 求实 现 以 下 功能 : 在 c select 表 上 创建 一 个 触发 器 tr_ 
select, 当 在 c select 表 字 段 中 修改 “成 绩 ? 后 ,触发 该 触发 器 ,检查 “成 绩 ” 值 是 否 在 0 一 100。 

10. 使 用 select into...outfile 语句 ,备份 表 student 的 全 部 数据 到 d 盘 的 bak 目录 下 一 
个 名 为 backupstudent. txt 的 文件 中 ,要 求 字 段 值 如 果 是 字符 则 用 双 引 号 标注 ,字段 值 之 间 
用 逗号 隔 开 ,每 行 以 问号 为 结束 标志 。 


MySQL 数据 库 模 拟 试题 1 参考 答案 


一 、 选 择 题 (每 题 1 分, 共 20 分 ) 
1~5. CBDBD 6~10. BADDB 11~15. AAAAA 16~20. AABDA 
二 、 填空 题 ( 每 空 1 分 , 共 10 分 ) 
1. 实体 属性 

2. my.ini 

3. 完全 安装 

4. 整数 “auto increment" 

5. null 

6. primary key 

7. index 

8. ignore 

三 、 阅读 程序 ,指出 下 列 程序 段 的 功能 (每 题 3 分 , 共 18 分 ) 

1. 创建 存储 过 程 ,输出 arts 表 的 指定 记录 的 数量 。 

2. 利用 explain 分 析 比 较 查 询 语句 中 使 用 like 关键 字 , 并 且 匹 配 的 字符 串 中 含有 “%” 
符 时 的 结果 。 

3. 使 用 mysqldump 备份 booksDB 和 test 数据 库 。 

4. 声明 变量 bookname 和 bookprice, 通 过 select ... into 语句 查询 指定 记录 并 为 变量 
赋值 。 

5. 创建 索引 ,分 析 使 用 索引 时 的 查询 情况 。 

6. 使 用 loop 语句 进行 循环 操作 ,id 值 小 于 等 于 10 之 前 ,将 重复 执行 循环 过 程 。 

四 、 简 答题 (每 小 题 3 分 , 共 12 分 ) 

1. 优化 性 能 是 通过 某 些 高 效 的 方法 提高 MySQL 数据 库 的 性 能 ,其 目的 是 为 了 使 
MySQL 数据 库 运 行 速度 更 快 、 占 用 的 磁盘 空间 更 小 。 性 能 优化 包括 优化 查询 速度 、 优 化 更 
新 速度 .优化 MySQL 服务 器 等 。 优 化 MySQL 数据 库 是 数据 库 管理 员 的 必 备 技能 。 

在 实际 工作 中 ,数据 的 查询 优化 可 以 有 效 地 提高 MySQL 数据 库 的 性 能 。 一 个 成 功 的 
数据 库 应 用 系统 的 开发 ,在 查询 优化 方面 一 定 会 付出 资源 。 对 查询 优化 的 处 理 , 不 仅 会 影响 
到 数据 库 的 工作 效率 ,而 且 会 给 社会 带 来 较 高 的 效益 。 

2. 排他 锁 又 称 为 X 锁 。 如 果 事 务 T1 获得 了 数据 行 D 上 的 排他 锁 , 则 Tl 对 数据 行 既 
可 读 又 可 写 。 事 务 T1 对 数据 行 D 加 上 排他 锁 , 则 其 他 事务 对 数据 行 D 的 任务 封锁 请 求 都 
不 会 成 功 ,直至 事务 T1 释放 数据 行 D 上 的 排他 锁 。 

共享 锁 又 称 为 S 锁 。 如 果 事 务 TI 获得 了 数据 行 D 上 的 共享 锁 , 则 TI 对 数据 项 D 可 
以 读 但 不 可 以 写 。 事 务 T1 对 数据 行 D 加 上 共享 锁 , 则 其 他 事务 对 数据 行 D 的 排他 锁 请 求 
不 会 成 功 ,而 对 数据 行 D 的 共享 锁 请 求 可 以 成 功 。 

3. 用 户 访 问 MySQL 服务 器 数据 的 工作 流程 具体 包括 如 下 内 容 : 
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CD 数据 库 用 户 访问 MySQL 服务 器 的 数据 时 ,首先 需要 选择 一 台 登 录 主机 ,然后 在 该 
登录 主机 上 开启 客户 机 ,输入 正确 的 账户 名 、 密 码 , 建 立 一 条 客户 机 与 服务 器 之 间 的 “通信 
链 路 ”。 

(2) 接着 数据 库 用 户 就 可 以 在 MySQL 客户 机 上 输入 MySQL 命令 ,这 些 命令 沿 着 该 通 
信 链 路 传送 给 MySQL 服务 实例 ,这 个 过 程 称 为 客户 机 向 MySQL 服务 器 发 送 请 求 。 

(3) 服务 实例 负责 解析 这 些 MySQL 命令 ,并 选择 一 种 执行 计划 运行 这 些 命令 ,然后 将 
执行 结果 沿 着 通信 和 链 路 返回 给 客户 机 ,这 个 过 程 称 为 服务 器 向 MySQL 客户 机 返回 响应 。 

COD 数据 库 用 户 关 闭 客户 机 ,通信 链 路 被 断 开 ,该 客户 机 对 应 的 会 话 结束 。 

A. 视图 为 数据 库 用 户 提 供 了 很 多 的 便利 ,主要 包括 以 下 几 个 方面 : 

(1) 简化 数据 查询 和 处 理 。 视 图 可 以 为 用 户 集中 多 个 表 中 的 数据 ,简化 用 户 对 数据 的 
查询 和 处 理 。 

(2) 屏蔽 数据 库 的 复杂 性 。 数 据 库 表 的 更 改 不 影响 用 户 对 数据 库 的 使 用 ,用 户 也 不 必 
了 解 复杂 的 数据 库 中 的 表 结 构 。 例 如 ,那些 定义 了 若干 张 表 连接 的 视图 ,就 将 表 与 表 之 间 的 
连接 操作 对 用 户 隐蔽 起 来 了 。 

(3) 安全 性 。 如 果 想 要 使 用 户 只 能 查询 或 修改 用 户 有 权限 访问 的 数据 ,也 可 以 只 授予 
用 户 访问 视图 的 权限 ,而 不 授予 访问 表 的 权限 ,这样 就 提高 了 数据 库 的 安全 性 。 

五 、 综 合 题 (每 小 题 4 分 , 共 40 分 ) 

l. alter tablec select 

add primer key (学 号 ,课程 号 ); 
alter table c select add constraint fk 1 foreign key (学 号 ) 
references student(^f 5 ) 


on update restrict 
on delete set null; 


2. select s. 姓 名 ,k. 课 程 名 ,x. 成 绩 
from course k, student s, c select x 


where k. 课 程 号 = x. 课 程 号 and s. 学 号 =x. 学 号 and s. 姓 名 = ' 黄 岩 '; 


3. create view V update 
as 
select * from c select where 课程 号 = 'c05126'; 
select * from v update; 


4. delimiter // 
create procedure upcourse( in courseid char(6), in newnamel char(9), 
out oldname char(9), out newname2 char(9)) 
begin 
set newname2 = newnamel; 
select oldname = 课程 名 from course 
where 课程 号 = courseid; 
update course set 课程 名 = newnamel 
where 课程 号 = courseid; 
end // 
delimiter; 
5. select * from course; 
exec upcourse ('c05126', 'MySQL', (Qnamel, @name2); 
select (Znamel + ' 已 更 改 为 : '+ @name2; 


grant select, insert on * to 'tuser'@ 'localhost' 
identified by '123abc ' 

with grant option; 

revoke all privileges, grant option 

from tuser(2 localhost; 


mysqldump -u root -p teach c select» d:/bak/teaching ss.sql 


delimiter // 

create triger tr select onc select 

after update for each row 

begin 

update from c select set c select. JL = old. 成 绩 
where new. 成 绩 > 100 or new. 成 绩 < 0; 

end// 


delimiter ; 


10. select * from student 


into outfile 'd:/bak/backupstudent. txt' 
fields 
terminated by'," 
optionally enclosed by "" 
lines 
terminated by'?'; 
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MySQL 数据 库 模 拟 试题 2 


说 明 : 本 试题 为 笔试 方式 ,考试 时 间 100 分 钟 ,总 计 100 分 。 
一 、 选 择 题 (每 题 1 分 , 共 20 分 ) 








1. 语句 “select dayofmonth(curdate()) ” "month';” 的 输出 结果 为 à 
A. month B. 当前 日 期 C. 本 月 第 几 天 D. 当前 月 份 
2. 候选 码 的 属性 可 以 有 T 
A. 多 个 B. 0 个 C. iT D. 1 个 或 多 个 
3. 在 MySQL 的 安装 过 程 中 , 若 选用 "启用 TCP/IP 网 络 ”, 则 MySQL 会 默认 选用 的 端 
口号 是 。 
A. 1521 B. 5560 C. 3306 D. 80 
4. 一 个 触发 器 能 定义 在 表 中 。 
A. =4 B. 一 个 或 者 多 个  C.—T£Ó ^ D. 任意 多 个 
5. 在 MySQL 中 ,通常 使 用 语句 来 进行 数据 的 检索 .输出 操作 。 
A. select B. insert C. delete D. update 
6. 在 select 语句 中 ,可 以 使 用 子 句 ,将 结果 集中 的 数据 行 根据 选择 列 的 值 进 
行 逻辑 分 组 ,以 便 能 汇总 表 内 容 的 子 集 , 即 实现 对 每 个 组 的 聚集 计算 。 
A. limit B. group by C. where D. order by 
7. 查看 现在 的 数据 库 mysqltest 中 所 有 表 的 命令 是 
A. show databases; B. create database mysgltest ; 
C. use mysqltest; 〈 回 车 ) D. show tables; 
8. 用 文本 方式 将 数据 装 入 数据 库 表 中 的 命令 是 


A. load data infile “D:/mysql. txt" into table mytable; 
B. source d: /mysql. sql; 
C. drop table mytable; 
D. delete from mytable; 
9. 用 于 显示 表 的 结构 的 命令 是 。 
A. create table mytable (name varchar(20). sex char(1)); 
B. describe mytable; 
C. insert into mytable values ("hyq"."M'); 


D. update mytable set sex— "f" where name= 'hyq': 


10. 在 mysql > 提示 行 下 输入 可 以 显示 帮助 命令 。 
A. help B. helps C. Xh D. A 或 C 
11. 在 MySQL 中 ,可 以 使 用 insert 或 语句 ,向 数据 库 中 一 个 已 有 的 表 插 入 一 
行 或 多 行 元 组 数据 。 


A. select B. insert C. replace D. update 


12. 在 MySQL 5. 7 以 上 版 本 的 系统 中 ,默认 的 存储 引擎 是 








A. MyISAM B. MEMORY C. InnoDB D. ARCHIVE 
13. MySQL 系统 中 , 表 结构 文件 的 扩展 名 是 
A. . frm B. . myd C. . myi D. . mdf 
14. 备份 是 在 某 一 次 完全 备份 的 基础 上 ,只 备份 其 后 数据 的 变化 。 
A. 比较 B. 检查 C. 增 量 D. 二 次 
15. 设 属性 A 是 关系 R 的 主 属性 , 则 属性 A 不 能 取 空 值 (nulD) ,这 是 
A. 参照 完整 性 规则 B. 用 户 定义 完整 性 规则 
C. 关系 完整 性 规则 D. 实体 完整 
16. WX RM S 的 元 组 个 数 分 别 为 100 和 300.95 & T Æ R 与 S 的 笛 卡 儿 积 , 则 全 
的 元 组 个 数 为 
A. 400 B. 10000 C. 30000 D. 90000 
17. 创建 表 时 ,不 允许 某 列 为 空 可 以 使 用 ° 
A. not null B. no null C. not blank D. no blank 
18. FJ 类 型 不 是 MySQL 中 常用 的 数据 类 型 。 
A. int B. var C. time D. char 
19. 不 是 外 键 定义 中 on delete 与 on update 的 设置 是 
A. cascade B. action C. restrict D. set null 
20. select * from city limit 3,7 描述 正确 的 是 
A. 获取 第 3 条 到 第 7 条 记录 B. 获取 第 3 条 到 第 10 条 记录 
C. 获取 第 4 条 到 第 10 条 记录 D. 获取 第 1 条 到 第 21 条 记录 
二 、 填空 题 (每 空 1 分 , 共 10 分 ) 
1. MySQL 数据 库 所 支持 的 SQL 语言 主要 包含 、 、 和 
MySQL 扩展 增加 的 语言 要 素 4 个 部 分 。 
2. 创建 唯一 性 索引 时 ,通常 使 用 的 关键 字 是 
3. 在 创建 表格 时 ,可 以 使 用 关键 字 使 当前 建立 的 表 为 临时 表 。 
4. 在 MySQL 中 ,可 以 使 用 语句 来 实现 权限 的 撤销 。 
5. E-R 图 是 数据 库 设计 的 工具 之 一 , 它 一 般 适 用 于 建立 数据 库 的 o 
6. 关键 字 能 够 将 两 个 或 多 个 select 语句 的 结果 连接 起 来 。 
7 是 表 、 视 图 、 存 储 过 程 、 触 发 器 等 数据 库 对 象 的 集合 ,是 数据 库 管理 系统 的 
核心 内 容 。 
8. select 语句 中 , 若 希 望 查询 的 结果 不 出 现 重 复元 组 , 则 应 在 select 子 句 中 使 用 
保留 字 。 


三 、 阅 读 程序 ,指出 下 列 程序 段 的 功能 (每 题 3 分 , 共 18 分 ) 
l. select 60+round(rand() * 40,0), 60+round(rand() * 40,0); 
2. create view v tabl 

as 

select quantity, price, quantity * price 

from tabl; 

select * from v tabl; 
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3. deliniter // 
create procedure pro score() 
begin 
select * from score; 
end // 
delimiter ; 


4. select sname from student 
where sno not in 


(select s no from score where final«60); 


5. grant select, update (id, name, age) on testdb. student 
To ''Adminl'(Z'localhost' identified by  'pword' 
with max connections per hour 30; 


6. mysqldump -t d:\backup testDB student -u root - p 
—- fields - terminated - by = , 
—- fields - optionally - enclosed- by = V" 
—- fields - escaped- by = ? 
—- lines - terminated- by = \r\n 
、 简 答题 (每 题 3 分 , 共 12 分 ) 
l. 简 述 连接 查询 的 分 类 和 特点 。 
2. 在 MySQL 中 可 以 授予 的 权限 有 哪 几 组 ? 
3. 简 述 事件 与 触发 器 的 区 别 。 
4. 简 述 数据 完整 性 的 分 类 和 特点 。 
五 、 综 合 题 (每 小 题 4 分 , 共 40 分 ) 
使 用 MySQL 命令 完成 操作 。 
1. 创建 一 个 新 的 数据 库 ,名 称 为 student。 
2. 在 数据 库 student 中 ,创建 一 个 学 生 信息 表 stu_info, 其 中 sname 字段 具有 唯一 性 。 
表 结 构 如 下 : 


stu info(sno char(10) ,sname char(10), sex char(2), 
birthday date, polity  char(10)) 


3. 向 表 stu info 中 搬入 1 条 记录 ,数据 如 下 : 

学 号 : 193552017, 姓名 : 王 秋 桐 ,性 别 : 女 , 出 生日 期 : 1999 09 09, 

4. 查询 stu_info 表 中 新 插入 的 记录 信息 。 

5. 将 polity 的 值 为 空 的 记录 用 "文学 ' 代 替 null 显示 。 

6. 查询 stu info 表 , 将 返回 的 记录 数 赋 给 变量 @RowsReturn ,并 显示 。 

7. 创建 一 个 视图 v_stu, 要 求 显示 stu info 表 中 所 有 姓 黄 的 同学 的 所 有 信息 。 

8. 向 表 stu_info 中 添加 一 个 “备注 ”字段 ,数据 类 型 为 char(40)。“ 和 备注? 字段 允许 为 
null, 

9. 按 性 别 分 组 , 求 出 stu. infot 表 中 的 男女 学 生 的 人 数 。 

10. 将 对 数据 库 teach 中 stu. info 表 的 select 权限 授予 数据 库 用 户 hans. 


MySQL 数据 库 模 拟 试题 2 参考 答案 


一 、 选 择 题 ( 每 题 1 分 , 共 20 分 ) 

1—5. DDCAA 6-10. BDABD 11-15. CCACA 16 一 20. CABBC 
二 、 填空 题 ( 每 空 1 分 , 共 10 分 ) 

.数据 定义 语言 (DDL) 数据 操纵 语言 (DML) 数据 控制 语言 (DCL) 
. unique 

. temporary 

. revoke 

union 

数据 库 

. distinct 

、 阅 读 程序 ,指出 下 列 程序 段 的 功能 (每 题 3 分 , 共 18 分 ) 

. 使 用 数学 函数 rand() 生 成 2 个 60 一 100 的 随机 整数 。 

. 创建 一 个 名 为 v_tabl 的 视图 ,并 显示 视图 中 的 所 有 数据 。 

. 创建 一 个 查看 score 表 的 存储 过 程 pro_score() ,每 次 调用 这 个 存储 过 程 的 时 候 都 会 
执行 select 语句 查看 表 的 数据 。 

A. 查询 期 末 成 绩 全 部 及 格 的 学 生 名 单 。 

5. 创建 新 账户 ,用 户 名 称 为 Adminl ,密码 为 pword, 允许 其 从 本 地 主机 访问 MySQL. 
对 学 生 表 有 查询 和 修改 权限 , 且 每 小 时 可 以 连接 服务 器 不 超过 30 次 。 

6. 使 用 mysqldump 命令 将 testl 数据 库 中 的 person 表 中 的 记录 导出 到 文本 文件 ,使 用 
fields 选项 ,要 求 字 段 之 间 使 用 逗号 " ,间隔 ,所 有 字符 类 型 字段 值 用 双 引 号 括 起 来 ,定义 转 
义 字 符 为 问号 “?”, 每 行 记录 以 回 车 换行 符 “\r\n” 结 尾 。 

四 、 简 答题 (每 题 3 分 , 共 12 分 ) 

1. 连接 运算 符 可 以 实现 多 个 表 查 询 。 连 接 可 分 为 三 种 : 内 连接 .外 连接 和 交叉 连接 。 
连接 操作 中 的 连接 条 件 由 被 连接 表 中 的 列 和 比较 运算 符 、 人 逻辑 运算 符 构 成 。 无 论 哪 种 连接 
都 不 能 对 text、ntext 和 image 数据 类 型 列 进行 直接 连接 。 

内 连接 (inner join) 使 用 比较 运算 符 进行 表 间 某 ( 些 ) 列 数据 的 比较 操作 ,并 列 出 这 些 表 
中 与 连接 条 件 相 匹配 的 数据 行 。 

外 连接 分 为 左 外 连接 、 右 外 连接 。 与 内 连接 不 同 的 是 .外 连接 不 只 列 出 与 连接 条 件 相 匹 
配 的 行 ,而 且 列 出 左 表 、 右 表 中 所 有 符合 搜索 条 件 的 数据 行 。 

交叉 连接 (cross join) 没 有 where 子 句 , 它 返回 连接 表 中 所 有 数据 行 的 笛 卡 儿 积 ,其 结 
果 集 合 中 的 数据 行 数 等 于 第 一 个 表 中 符合 查询 条 件 的 数据 行 数 乘 以 第 二 个 表 中 符合 查询 条 
件 的 数据 行 数 。 

2. 在 MySQL 中 可 以 授予 的 权限 有 这 样 几 组 : 列 权 限 ; 表 权 限 ;数据 库 权 限 ;用 户 权 限 。 
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3. 事件 和 触发 器 相似 ,都 是 在 某 些 事情 发 生 的 时 候 才 被 启动 ,因此 事件 也 可 称 作 临时 
触发 器 (temporal trig-ger) 。 其 中 ,事件 是 基于 特定 时 间 周 期 触发 来 执行 某 些 任务 ,而 触发 
器 是 基于 某 个 表 所 产生 的 事件 触发 的 ,它们 的 区 别 也 在 于 此 。 

4. 确保 持久 化 数据 检索 不 出 错 对 于 数据 管理 来 说 非常 关键 ,数据 完整 性 ,能 保证 查询 
结果 的 正确 性 ,数据 完整 性 的 分 类 和 特点 如 下 : 

(1) 实体 完整 性 。 实 体 完 整 性 是 指 关 系 的 主 关键 字 不 能 取 * 空 值 ”。 一 个 关系 对 应 现实 
世界 中 的 一 个 实体 集 。 在 关系 模式 中 ,以 主 关键 字 作为 唯一 性 标识 ,而 主 关键 字 中 的 属性 
( 称 为 主 属性 ) 不 能 取 空 值 。 

(2) 域 完整 性 确保 属性 中 只 允许 一 个 有 效 数据 。 域 是 属性 可 能 值 的 范围 ,如 整数 .日 期 
或 字符 。 是 否 可 以 是 空 值 也 是 域 完整 性 的 一 部 分 。 

(3) 参照 完整 性 。 参 照 完整 性 是 定义 建立 关系 之 间 联 系 的 主 关键 字 与 外 部 关键 字 引 用 
的 约束 条 件 。 关 系数 据 库 中 通常 包含 多 个 存在 相互 联系 的 关系 ,关系 与 关系 之 间 的 联系 是 
通过 公共 属性 来 实现 的 。 

(4) 事务 完整 性 。 事 务 可 以 确保 每 个 逻辑 单元 的 工作 (如 插入 100 行 或 更 新 1000 行 数 
据 ) 作 为 单个 事务 执行 。 事 务 可 通过 其 4 个 基本 属性 检测 数据 库 产 品 的 质量 , 即 原子 性 、 一 
致 性 .隔离 性 和 持久 性 。 

(5) 用 户 定义 完整 性 。 用 户 定义 完整 性 则 是 根据 应 用 环境 的 要 求 和 实际 的 需要 ,对 某 
一 具体 应 用 所 涉及 的 数据 提出 约束 性 条 件 。 用 户 定义 完整 性 主要 包括 字段 有 效 性 约束 和 记 
录 有 效 性 。 

五 、 综 合 题 (每 小 题 4 分 . 共 40 分 ) 


l. create database student; 





2. use student; 
create table stu info 
( sno char(10) primary key, 
sname char(8) not null, 
sex char(2) not null, 
birthday date not null, 
polity char(10) unll, 
constraint uk name unique(sname) 
3. insert into stu info (Sno, sname, sex) 
values('193552017', ' 王 秋 桐 ', ' 女 ', 1999 09 09'); 
4. select sno as 学 号 ，sname as 姓名 , sex as 性 别 , polity as 社团 
from stu info 
where sno = '193552017'; 
5. update stu info set polity2 ' 文 学 ' 
where polity is null; 
6. select @RowsReturn = count(* ) from stu info; 
# 显示 变量 的 值 
select (ÜRowsReturn 'select 返回 的 记录 数 '; 
7. create view v stu 
as 
select * from stu info 


where sname like '# $% '; 
8. alter table stu_info add column 
9. select 单位 ,count( * ) as ' A t" 
from stu_infot 


group by sex; 


10. grant select on teach. stu_info 
to 'hans'@'localhost'; 


备注 char(40) null; 
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MySQL 数据 库 模 拟 试题 3 


说 明 : 本 试题 为 笔试 方式 ,考试 时 间 100 分 钟 ,总 计 100 分 。 
一 、 选 择 题 (每 题 1 分 , 共 20 分 ) 


1. 在 MySQL 数据 库 中 null 表示 r 

A. 0 B. 空格 C. 未 确定 值 D. 其 他 
2. 请 句 块 是 一 个 MySQL 语句 集合 ,以 结束 。 

A. begin B. “y” C. go D. end 
3. 存储 程序 中 选择 语句 有 

A. if B. while C. select D. switch 
4. 语句 select * from city limit 5.10 描述 正确 的 是 : 


A. 获取 第 6 条 到 第 10 条 记录 
B. 获取 第 5 条 到 第 10 条 记录 
C. 获取 第 6 条 到 第 15 条 记录 
D. 获取 第 5 条 到 第 15 条 记录 
. 视图 是 一 个 “ 虚 表 ”, 视 图 的 构造 基于 


a 


A. 基本 表 B. 视图 C. 基本 表 或 视图 D. 数据 字典 
6. 使 用 select 将 表 中 数据 导出 到 文件 ,可 以 使 用 T^. 

A. to file B. into file C. out to file D. into outfile 
7. TFA 语句 用 来 定义 游标 。 

A. create B. declare 

C. declare ...cursor for ... D. show 
8. 下 列 说 法 中 错误 的 是 o 


A. 常用 触发 器 有 insert update 和 delete 3 种 

B. 对 于 同一 张 数据 表 , 可 以 同时 有 两 个 before update 触发 器 
C. new 表 在 insert 触发 器 中 用 来 访问 被 插入 的 行 

D. old 表 中 值 只 读 不 能 被 更 新 


9. 删除 列 的 指令 是 

A. alter table ... delete ... B. alter table ... delete column... 

C. alter table ... drop ... D. alter table ... drop column... 
10. 中 提供 了 执行 mysqldump 之 后 对 数据 库 的 更 改进 行 复制 所 需要 的 信息 

的 功能 。 
A. 二 进 制 日 志文 件 B. MySQL 数据 库 

C. MySQL 配置 文件 D. bin 数据 库 

11. 不 可 对 视图 执行 的 操作 有 P 


A. select B. insert C. delete D. create index 


. 下 列 语句 中 ， 不 是 表 数据 的 基本 操作 语句 。 
A. create B. insert C. delete D. update 
. 下 列 描述 正确 的 是 ° 


A. 一 个 数据 库 只 能 包含 一 个 数据 表 B. 一 个 数据 库 可 以 包含 多 个 数据 表 
C. 一 个 数据 库 只 能 包含 两 个 数据 表 D. 一 个 数据 表 可 以 包含 多 个 数据 库 


. 设置 表 的 默认 字符 集 关 键 字 是 
A. default character B. default set 
C. default D. default character set 

. 使 用 insert 插入 记录 时 ,可 使 用 关键 字 忽 略 会 导致 重复 关键 字 的 错误 
A. no same B. ignore C. repeat D. unique 

.对 于 replace 语句 ,描述 错误 的 是 。 


A. replace 语句 返回 一 个 数字 以 表示 受 影响 的 行 ,包含 删除 行 和 插入 行 的 总 和 
D. 通过 返回 值 可 以 判断 是 否 增加 了 新 行 还 是 替换 了 原 有 行 

C. 因 主 键 重复 插入 失败 时 直接 更 新 原 有 行 

D. 因 主 键 重复 插入 失败 时 先 删除 原 有 行 再 插入 新 行 





17. 要 快速 完全 清空 一 张 表 可 使 用 语句 。 
A. truncate table B. delete table 
C. drop table D. clear table 
18. 使 用 create view 创建 视图 时 ,如 果 给 定 了 子 句 ,能 替换 已 有 视图 。 
A. all replace B. OR replace C. replace D. replace all 
19. 通过 以 下 哪个 语句 临时 关闭 事件 e test? 
A. alter event e_test disable B. alter event e_test drop 
C. alter event e_test enable D. alter event e_test delete 
20. delete from S where 年 龄 > 60 语句 的 功能 是 
A. 从 S 表 中 彻底 删除 记录 B. S 表 中 年 龄 大 于 60 岁 的 记录 被 删除 
C. 删除 S 表 D. 删除 S 表 的 年 龄 列 
二 、 填空 题 (每 空 1 分 , 共 10 分 ) 
1. 服务 器 是 用 来 、 、 和 停止 MySQL 服务 的 。 
2. 以 @ 作 为 首部 的 变量 在 MySQL 系统 中 称 为 
3. select 语句 的 完整 语法 较 复杂 ,但 至 少 包括 的 部 分 有 ; 使 用 关键 
字 可 以 把 重复 行 屏蔽 ,将 多 个 查询 结果 返回 一 个 结果 集合 的 运算 符 是 è 
4. 声明 游标 的 命令 是 ,关闭 游标 的 命令 是 " 
5. MySQL 安装 包含 典型 安装 .定制 安装 和 三 种 安装 类 型 。 


三 、 阅 读 程序 ,指出 下 列 程序 段 的 功能 (每 题 3 分 : 共 18 分 ) 


l. select * from course left join score 


on course. cno = score. cno; 第 

2. select date sub('2017 - 01 - 02', interval 31 day) as coll, b 
subdate('2017 — 01 — 02', interval 31 day) as col2; sd 

分 
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3. delimiter // 
create function fname () 
returns char(20) 
begin 
return (select sname from student where phone- '78548075'); 
end // 


delimiter ; 
4. explain select * from score where final» 90; 
5. grant usage on *.*  to'testUser'(2'localhost'identified by  'pwdone '; 


6. select * from test.student into outfile "D:/student. txt" 
fields 
terminated by '," 
enclosed by '\"' 
escaped by V'' 
lines 
terminated by '\r\n'; 
、 简 答题 (每 题 3 分 , 共 12 分 ) 
1. 简 述 事件 与 触发 器 的 区 别 。 
2. 简要 说 明 事务 的 原子 性 的 特点 。 
3. 列举 MySQL 的 系统 特性 。 
4. MySQL 数据 库 备 份 与 恢复 的 常用 方法 有 哪些 ? 
五 、 综 合 题 (每 小 题 4 分 , 共 40 分 ) 
使 用 MySQL 语句 完成 操作 。 现 有 一 个 关于 设备 管理 系统 的 数据 库 equip_gl, 数 据 库 
中 有 下 列 3 个 表 , 参 考 表 结构 如 下 : 
CD 设备 表 equipment(eno,ename,ebuyday,etypeid,etypename); 
其 属性 含义 依次 为 设备 编号 (主键 ) ,设备 名 称 , 购 入 日 期 ,设备 分 类 号 ,设备 分 类 名 。 
(2) 雇员 表 employee(Cpno. pname. psex.pbirth. pposition) ; 
其 属性 依次 为 员工 号 (主键 ) .姓名 ,性别 , 出 生日 期 ,岗位 。 
(3) 设备 使 用 表 u_equip(pno，eno ,borrowday,useday, ufee); 
其 属性 依次 为 设备 编号 ,员工 号 , 借 出 日 期 ,使 用 天 数 , 收 费 金 额 。 
1. 创建 使 用 表 u_equip。( 要 求 : 包含 主键 约束 和 check 约束 检查 “收费 金额 二 一 50”) 。 
2. 添加 一 个 人 员 记 录 , 员 工 号 为 17009, 姓 名 为 “ 韩 伟 和 ”, 性 别 为 * 男 ”, 出 生日 期 为 
1993-10-08, 职 位 为 “ 副 主任 ”。 
3. 将 设备 名 称 为 “复印 机 ”的 收费 金额 修改 为 360。 
4. 删除 姓名 为 “ 马 怡 闻 ” 的 人 员 信 息 。 
5. 查询 每 种 设备 平均 收费 金额 超过 500 元 的 设备 编号 和 平均 收费 金额 。 
6. 检索 借用 设备 的 收费 金额 超过 2000 元 的 员工 姓名 、 设 备 编号 .设备 名 称 。 
7. 检索 借 出 设备 借用 90 天 以 上 的 员工 姓名 、 设 备 编号 。 
8. 将 设备 使 用 u_equip 的 查询 、 修 改 权 限 授予 用 户 manager, 并 允许 该 用 户 将 此 权限 授 
予 其 他 用 户 。 
9. 定义 视图 v_employee, 完 成 如 下 功能 : 输出 没有 使 用 设备 的 人 员 信 息 。 
10. 创建 一 个 after 触发 器 ,要 求实 现 以 下 功能 : 在 pmployee 表 上 创建 一 个 触发 器 tr_ 
pmployee, 修 改 pmployee 表 的 字段 pno 数据 后 ,触发 该 触发 器 ,同时 u_equip 的 pno 数据 更 新 。 


MySQL 数据 库 模 拟 试题 3 参考 答案 


一 、 选 择 题 (每 题 1 分, 共 20 分) 

1—5. CDACC 6~10. DCBDA 11~15. BABDB 16~20. CABAB 

二 、 填空 题 ( 每 空 1 分 , 共 10 分 ) 

. 启动 暂停 重启 

. 会 话 变量 

. select from distinct 

. declare close 

.完全 安装 

、 阅 读 程序 ,指出 下 列 程序 段 的 功能 (每 题 3 分 , 共 18 分 ) 

. 以 课程 号 为 连接 条 件 , 利 用 左 连 接 查 询 所 有 课程 的 成 绩 。 

. 使 用 date sub 和 subdate 函数 执行 日 期 减法 操作 。 

. 创建 一 个 存储 函数 ,参数 定义 为 空 ,返回 一 个 char(20) 类 型 的 结果 。 

分 析 查 询 select * from score where final > 90。 

.使 用 grant 语句 将 testUser 用 户 的 密码 修改 为 "pwdone”。 

. 使 用 select...into outfile 将 test 数据 库 中 的 student 表 中 的 记录 导出 到 文本 文件 ,使 
用 fields 选项 和 lines 选项 ,要 求 字 段 之 间 使 用 逗号 “, ”间隔 ,所 有 字段 值 用 双 引 号 括 起 来 ， 
定义 转 义 字符 为 单 引号 “\”。 

四 、 简 答题 (每 题 3 分 . 共 12 分 ) 

1. 事件 和 触发 器 相似 ,都 是 在 某 些 事情 发 生 的 时 候 才 被 启动 ,因此 事件 也 可 称 作 临时 
触发 器 (temporal trig-ger) 。 其 中 ,事件 是 基于 特定 时 间 周 期 触发 来 执行 某 些 任务 ,而 触发 
器 是 基于 某 个 表 所 产生 的 事件 触发 的 ,它们 的 区 别 也 在 于 此 。 

2. 事务 的 所 有 操作 必须 完成 ,否则 事务 将 被 撤销 。 也 就 是 说 ,事务 是 作为 一 个 整体 的 
单位 处 理 的 ,不 可 以 被 分 割 。 

3. MySQL 数据 库 的 应 用 非常 广泛 ,主要 是 因为 其 具有 4 个 方面 的 优势 。 

COD MySQL 数据 库 是 开放 源 代码 的 数据 库 。 任 何人 都 可 以 获取 MySQL 数据 库 的 源 
代码 ,可 以 修改 MySQL 数据 库 的 缺陷 ,并 以 任何 目的 来 使 用 该 数据 库 。 

(2) MySQL 数据 库 的 跨 平台 性 。MySQL 不 仅 可 以 在 Windows 系列 的 操作 系统 上 运 
行 ,还 可 以 在 UNIX、Linux 和 Mac OS 等 操作 系统 上 运行 。 

(3) MySQL 的 价格 优势 。MySQL 数据 库 是 一 款 自由 软件 ,社区 版 本 的 MySQL 数据 
库 软件 都 是 免费 使 用 的 ,相对 于 Oracle, SQL Server 和 DB2 这 些 价格 昂贵 的 商业 软件 ， 
MySQL 数据 库 具有 绝对 的 价格 优势 。 

(4) 功能 强大 、 使 用 方便 。MySQL 数据 库 是 一 个 多 用 户 、 多 线程 的 SQL 数据 库 服务 
器 , 它 是 C/S 结构 的 实现 ,由 一 个 服务 器 守护 程序 mysqlld 和 很 多 不 同 的 客户 程序 及 库 
组 成 。 
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4. MySQL 数据 库 备份 与 恢复 的 常用 方法 有 : 

CD 使 用 SQL 语句 备份 和 恢复 表 数 据 。 

(2) 使 用 MySQL 客户 端 实用 程序 备份 和 恢复 数据 。 
(3) 使 用 MySQL 图 形 界面 工具 备份 和 恢复 数据 。 
(4) 直接 利用 复制 完成 备份 和 恢复 。 

五 、 综 合 题 (每 小 题 4 分 , 共 40 分 ) 


l. create table u equip( 
pnochar(8) , 
eno,char(8), 
borrowday date, 
useday samllint , 
fee samllint constrint check(fee»- 50), 
primary key(pno, eno) 
) 
2. insert into pmployee(pno, pname, psex, pbirth, pposition) 
values('17009', ' 韩 伟 和 '，' 男 ' 1993-10- 08', 'WEH'); 
3. update u equip set fee=360 where eno in ( 
select eno from equipment 


where ename = 'Á EL") ; 


4. delete from employee 
where pname = ' 马 怡 闻 '; 


5. select eno,avg(fee) from u_equip 
group by eno having avg(fee)» 500; 


6. select pname, equipment. eno, ename 
from equipment, u equip, employee 
where equipment. eno = u equip. eno and employee. pno= u equip. pno and fee ^ 2000 
order by pname; 
7. select pname, employee. eno 
from employee, u equip 
where and employee. pno = u equip. pno and useday > = 90 


8. grant select, update on u. equip 
to manager(2localhost with grant option; 


9. create view v employee 
as 
select pno, pname, psex, pbirth, pposition 
from pmployee 
where pno not in ( select pno from u equip); 


10. delimiter // 
create triger tr pmployee on pmployee 
after update for each row 
begin 
update u equip set  pmployee. pno = new. pno 
where pmployee. pno = old. pno; 
end// 


delimiter; 


MySQL 数据 库 模 拟 试题 4 


说 明 : 本 试题 为 笔试 方式 ,考试 时 间 100 分 钟 , 总 计 100 分 。 
一 、 选 择 题 (每 题 1 分 , 共 20 分) 


1. 根据 关系 模式 的 完整 性 规则 ,一 个 关系 中 的 主键 
A. 不 能 由 两 列 组 成 B. 不 能 成 为 另 一 个 关系 的 外 部 键 
C. 不 允许 空 值 D. 可 以 取 空 值 
2. MySQL 使 用 文件 中 的 配置 参数 。 
A. mylarger. ini B. mysmall. ini C. default. ini D. my.ini 
3. 下 列 关 于 统计 函数 count( 字 符 串 表 达 式 ) 的 叙述 中 ,正确 的 是 A 


A. 返回 字符 表达 式 中 值 的 个 数 , 即 统计 记录 的 个 数 
B. 统计 字段 应 该 是 数字 数据 类 型 
C. 字符 串 表 达 式 中 可 以 是 字段 名 
D. 以 上 都 不 正确 
4. 下 面 不 是 备份 数据 库 的 理由 。 
A. 数据 库 崩 演 时 恢复 
B. 将 数据 从 一 个 服务 器 转移 到 另外 一 个 服务 器 
C. 记录 数据 的 历史 档案 


D. 转换 数据 
5. 以 下 哪个 语句 用 于 撤销 权限 ? 
A. delete B. drop C. revoke D. update 
6. 选择 要 执行 操作 的 数据 库 , 应 该 用 MySQL 命令 。 
A. use B. go C. exec D. DB 
7. 下 面 关 于 数据 库 中 表 的 行 和 列 的 叙述 正确 的 是 . 
A. 表 中 的 行 是 有 序 的 , 列 是 无 序 的 B. 表 中 的 列 是 有 序 的 , 行 是 无 序 的 
C. 表 中 的 行 和 列 都 是 有 序 的 D. 表 中 的 行 和 列 都 是 无 序 的 
8. 在 MySQL 语言 中 ,条 件 “age between 20 and 30” 表 示 年 龄 为 20—30. H. 
A. 包括 20 岁 和 30 岁 B. 不 包括 20 岁 和 30 岁 
C. 包括 20 岁 但 不 包括 30 岁 D. 包括 30 岁 但 不 包括 20 岁 
9. 显示 当前 所 有 数据 库 的 命令 是 ë 
A. show databases B. show database 
C. list databases D. list database 
10. 有 订单 表 orders, 包 含 用 户 信息 userid, 产 品 信 息 productid, 以 下 语句 能 


够 返回 至 少 被 订购 过 两 回 的 productid。 
A. select productid from orders where count(productid) —1 


B. select productid from orders where max(productid) —1 
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20. 


i 
2. 
3. 
4. 
中 ,asc 
5. 
6. 
Ts. 
织 成 一 
8. 


l. 


C. select productid from orders where having count ( productid) — 1 group 
by productid 
D. select productid from orders group by productid having count( productid) —1 


. 在 实际 使 用 中 ,MySQL 所 支持 的 触发 器 有 3 种 ,不 包括 触发 器 o 

A. insert B. delete C. update D. select 

只 修改 列 的 数据 类 型 的 指令 是 

A. alter table ... alter column B. alter table ... modify column... 

C. alter table ... update ... D. alter table ... update column... 
. 选择 当前 数据 库 的 命令 是 

A. shows B. create C. use D. show 
. select 语句 中 删除 结果 集 重 复 行 的 命令 是 

A. where B. having C. distinct D. order by 
. 下 列 选项 中 属于 创建 数据 库 的 语句 是 


A. create database B. alter database C. drop database D. 以 上 都 不 是 





. 查询 student 表 中 id 值 在 2 7 之 间 的 学 生 姓 名 ,应 该 使 用 关键 字 
A. between and B. in C. like D. OR 
. 用 is null 关键 字 来 判断 字段 的 值 是 否 为 空 值 , 那 is null 关键 字 应 该 在 之 
A. order by B. where C. select D. limit 
在 聚合 函数 中 ,用 来 统计 记录 条 数 的 函数 是 
A. sum() B. avg() C. max() D. count() 
. select 语句 中 ,使 用 子 句 可 按 指定 列 的 值 分 组 。 
A. where B. having C. group by D. order by 
要 想 移 除 账户 ,应 使 用 语句 。 
A. delete user B. drop user C. delete priv D. drop priv 


二 、 填空 题 (每 空 1 分, 共 10 分 ) 


是 在 数据 库 中 定义 的 一 些 完成 特定 功能 的 SQL 语句 的 集合 。 





函数 round(58. 3049,2) 的 返回 值 是 
bool 型 数据 用 于 存储 逻辑 值 , 它 只 有 两 种 状态 , 即 和 
select 语句 中 , 若 希 望 将 查询 结果 排序 , 则 应 在 select 语句 中 使 用 order n" 子 句 ,其 


选项 表示 升序 ， 选项 表示 降序 。 

在 MySQL 中 ,查询 时 想 要 输出 显示 2 一 12 行 信息 ,可 用 到 关键 字 。 

聚合 函数 中 ,用 于 求 出 某 个 字段 最 大 值 的 函数 是 " 

select 语句 的 执行 过 程 是 从 数据 库 中 选取 匹配 的 特定 记录 和 字段 ,并 将 这 些 数据 组 


个 结果 集 ,然后 以 的 形式 返回 。 
在 MySQL 中 ,清空 表 的 数据 可 以 使 用 和 命令 实现 。 





三 、 阅 读 程序 ,指出 下 列 程序 段 的 功能 (每 题 3 分, 共 18 分 ) 


add num: loop 
set @count = (Zcount + 1; 


if @count = 30 
then leave add num ; 
endif; 
end loop add num ; 
2. select studentno, sname, phone, Email 
from student 
where phone regexp '7$ '; 
3. create index Multi Col2 
on test(first, middle, last); 
4. delimiter // 
create procedure cproc(out parl int) 


begin 
select count(*) into paraml from frus; 
end // 
delimiter ; 
5. mysql -u root -p -- vertical 
—- execute = "select * from pers;" test >D:\persl. 
6. mysqlbinlog —- stop- date = "2017 - 03 - 30 16:30:30" 


txt 


D: \MySQL\ log\binlog\binlog. 000027 | mysql - uuser - ppass 


四 、 简 答题 (每 题 3 分 . 共 12 分 ) 
. 简 述 数据 库 系统 的 组 成 。 


1 
2. 简 述 利用 truncate table 和 delete 语句 删除 表 数 据 时 有 什么 区 别 。 
3 


. 简 述 并 发 控制 可 能 产生 的 原因 。 
A. 简 述 在 数据 库 中 创建 索引 的 必要 性 。 
五 、 综 合 题 (每 小 题 4 分 , 共 40 分 ) 


MySQL 数据 库 teach 中 有 学 生 信 息 表 stu_info 和 学 生 选 课 成 绩 表 se_score, 创 建 表 结 
构 的 命令 如 下 所 示 , 利 用 SQL 语言 写 出 以 下 各 题 的 操作 命令 。 


create table stu info( 
学 号 char(4) primary key, 
姓名 char(8) null, 
性 别 char(2) null, 
入 学 成 绩 int null, 
出 生日 期 datetime null 
); 
create table se score( 
学 号 char(4) not null, 
课程 编号 char(5) not null, 
成 绩 int null, 
primary key (学 号 ,课程 编号 ) 
); 


1. 为 数据 库 中 se score 表 的 “学 号 ” 列 创建 一 个 foreign key 约束 fk. se. 2 BH stu. info 


表 的 “学 号 ” 列 。 
2. 显示 平均 成 绩 低 于 80 分 的 学 生 的 学 号 、 姓 名 。 


3. 显示 单 科 成 绩 最 高 的 学 生 的 学 号 、 姓 名 及 课程 编号 。 
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4. 在 stu_info 表 中 的 “学 号 ? 列 上 创建 一 个 普通 索引 index_xh。 

5. 建立 视图 v_score, 查 询 所 有 学 生 的 姓名 和 平均 分 数 。 

6. 创建 一 个 存储 过 程 p_delete, 删 除 se score 表 中 指定 学 号 的 记录 。 

7. 在 stu. info 表 上 创建 一 个 触发 器 stu_trig, 当 删除 stu_info 表 记 录 时 ,同步 删除 se_ 
score 表 中 指定 的 记录 。 

8. 求 出 男女 学 生 的 平均 人 学 成 绩 。 

9. 为 stu_info 添加 一 个 能 够 存储 照片 的 字段 。 

10. 使 用 mysqldump 命令 备份 数据 库 teach 中 的 stu. info 表 和 se. score 表 。 


MySQL 数据 库 模 拟 试题 4 参考 答案 


一 、 选 择 题 (每 题 1 分, 共 20 分 ) 

1 一 5. CDCCC 6~10. ADAAD 11~15. DBCCA 16~20. ABDCB 

二 、 填空 题 (每 空 1 分 , 共 10 分 ) 

.存储 过 程 

. 58.30 

. true, false 

B desc 

. limit 

. max() 

.临时 表 

. truncate delete 

、 阅 读 程序 ,指出 下 列 程序 段 的 功能 (每 题 3 分 , 共 18 分 ) 

.循环 执行 count 加 1 的 操作 。 当 count 的 值 等 于 30 时 ,使 用 leave 语句 跳出 循环 。 
. 查询 student 表 中 学 生 电 话 号 码 尾数 为 7 的 学 生 的 信息 。 

. 使 用 create index 建立 名 称 为 MultiCol2 的 组 合 索 引 。 

. 创建 一 个 获取 frus 表 记 录 条 数 的 存储 过 程 cproc, 利 用 count( * ) 计 算 后 把 结果 放 入 
参数 parl 中 。 

5. 使 用 MySQL 命令 导出 test 数据 库 中 pers 表 中 的 记录 到 文本 文件 ,使 用 --vertical 
参数 显示 结果 。 

6. 使 用 mysqlbinlog 恢复 MySQL 数据 库 到 2017 年 3 月 30 日 16:30:30 时 的 状态 。 

四 、 简 答题 (每 题 3 分 , 共 12 分 ) 

1. 数据 库 系 统 (Database System,DBS) 通 常 由 硬件 .软件 .数据 库 和 用 户 组 成 ,管理 的 
对 象 是 数据 。 其 中 软件 主要 包括 操作 系统 、 各 种 宿主 语言 .实用 程序 以 及 数据 库 管理 系统 。 
数据 库 系 统 包 括 四 大 组 件 : 用 户 数据、 软件 和 硬件 。 

CD 用 户 (Users)。 用 户 执行 DDL 语言 定义 数据 库 架 构 ,使 用 DML 语言 新 增 、 删 除 、 更 
新 和 查询 数据 库 的 数据 ,通过 操作 系统 访问 数据 库 的 数据 。 按 不 同 角 色 划 分 ,用 户 可 以 分 为 
多 种 ,如 终端 用 户 (End-Users)、 数 据 库 设 计 者 (Database Designers)、 系 统 分 析 师 (System 
Analyst. SA) ,程序 员 (Application Programmer) 和 数据 库 管理 员 等 。 数 据 库 管理 员 负 责 创 
建 、 监 控 和 维护 整个 数据 库 , 一 般 是 由 业务 水 平 较 高 ,资历 较 深 的 人 员 担 任 。 

(2) 数据 (Data) 。 数 据 库 系统 中 的 数据 种 类 包括 永久 性 数据 (Persistent Data) , 2 513 
据 (Indexes) ,数据 字典 (Data Dictionary) 和 事务 日 志 (Transaction Log) 等 。 

(3) 软件 (Software) 。 指 在 数据 库 环境 中 使 用 的 软件 ,包括 数据 库 管理 系统 .应 用 程序 
和 开发 工具 (Development Tools) 等 。 

(4) 硬件 (Hardware)。 安 装 数据 库 相 关 软 件 的 硬件 设备 ,包含 主机 (CPU ,内 存 和 网 卡 


Pa 人 


MySQL 4t 4E E e JH 5 7E A LR ÉE E 5 Edu 





等 ) .磁盘 阵列 、 光 驱 和 备份 装置 等 。 

2. 为 什么 要 用 truncate table 语句 代替 delete 语句 ? 24 ff FH. truncate table 语句 时 , 记 
录 的 删除 是 不 作 记录 的 。 也 就 是 说 ,这 意味 着 truncate table 要 比 delete 快 得 多 。 

3. 多 个 用 户 访问 同一 个 数据 资源 时 ,可 能 出 现 的 一 些 并 发 问题 ,并 发 控制 可 能 产生 的 
原因 如 下 : 

CD 更 新 丢失 。 当 两 个 或 多 个 事务 选择 同一 行 ,每 个 事务 都 不 知道 其 他 事务 的 存在 。 
最 后 的 更 新 将 覆盖 其 他 事务 所 做 的 更 新 ,从 而 导致 数据 丢失 。 
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五 、 综 合 题 (每 小 题 4 分 , 共 40 分 ) 
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on update cascade 
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select se score. 学 号 
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group by se score. 学 号 
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on stu info for each row 
begin 
select (sno = 学 号 from old; 
delete from se score Where 学 号 = @sno ; 
end// 
delimiter ; 
8. select avg(stu info. 人 学 成 绩 ) as 平均 入 学 成 绩 ,性 别 
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MySQL 数据 库 模 拟 试题 5 


说 明 : 本 试题 为 笔试 方式 ,考试 时 间 100 分 钟 ,总计 100 分 。 
一 、 选 择 题 (每 题 1 分 , 共 20 分) 





1. 下 列 语句 用 于 创建 视图 。 
A. create triger B. create procedure 
C. create view D. create table 
2. 在 关系 数据 库 中 ,为 了 简化 用 户 的 查询 操作 ,而 又 不 增加 数据 的 存储 空间 , 则 应 该 创 
建 的 数据 库 对 象 是 
A. table B. index C. cursor D. view 
3. 在 MySQL 数据 库 自 带 的 命令 工具 中 ， 工具 执行 管理 操作 的 客户 程序 。 例 
如 创建 或 删除 数据 库 ,或 者 清除 所 有 缓存 的 主机 和 所 有 日 志 等 。 
A. mysql B. mysqladmin 
C. mysqlshow D. mysqlbinlog 
4. 关于 truncate table 描述 不 正确 的 是 ° 


A. truncate 将 删除 表 中 的 所 有 数据 

B. 表 中 包含 auto_incerement 列 ,使 用 truncate table 可 以 重 置 序列 值 为 该 列 的 初 
始 值 

C. truncate 操作 比 delete 操作 占用 资源 多 

D. truncate table 删除 表 , 然 后 重新 构建 表 


5. 下 列 几 种 情况 下 ,不 适合 创建 索引 的 是 š 
A. 列 的 取 值 范围 很 小 B. 用 作 查 询 条 件 的 列 
C. 频繁 搜索 范围 的 列 D. 连接 中 频繁 使 用 的 列 
6. 在 视图 上 不 能 完成 的 操作 是 o 
A. 更 新 基本 表 数 据 B. 查询 
C. 在 视图 上 定义 新 的 基本 表 D. 在 视图 上 定义 新 视图 
7. 创建 索引 是 为 了 e 
A. 提高 存 取 速度 B. 减少 WO 
C. 节约 空间 D. 减少 缓冲 区 个 数 
8. 为 了 使 索引 键 的 值 在 基本 表 中 唯一 ,在 创建 索引 的 语句 中 应 使 用 保留 字 
A. unique B. count C. distinct D. union 
9. 关于 视图 ,下 列 哪 一 个 说 法 是 错误 的 ? 
A. 视图 是 一 种 虚拟 表 B. 视图 中 也 保存 有 数据 
C. 视图 也 可 由 视图 派生 出 来 D. 视图 保存 在 select 查询 中 
10. 在 创建 数据 库 时 ,每 个 数据 库 都 对 应 存放 在 一 个 与 数据 库 同 名 的 m. 


A. 文件 B. XAK C. 路 径 D. 以 上 都 不 是 


11. MySQL fi 文件 中 的 配置 参数 。 


A. my-larger. ini B. my-small. ini C. my-huge. ini D. my. ini 
12. 下 列 选 项 中 属于 删除 数据 库 的 语句 是 

A. create database B. use database 

C. drop database D. 以 上 都 不 是 
13. 下 列 聚 合 函数 不 忽略 空 值 Onull) 的 是 。 

A. sum( 列 名 ) B. max( 列 名 ) C. count( * ) D. avg( 列 名 ) 
14. 下 列 语句 用 于 释放 预 处 理 语句 。 

A. prepare B. execute C. deallocate D. using 
15. 在 SQL 中 ,下 列 涉及 空 值 的 操作 ,不 正确 的 是 è 

A. age is null B. age is not null 

C. age=null D. not(age is null) 
16. select 语句 中 ， 子 句 用 于 选择 满足 给 定 条 件 的 元 组 。 

A. where B. having C. group by D. order by 


17. 为 了 提高 特定 查询 的 速度 ,对 SC(Sno, Cno, degree) 关 系 创建 唯一 性 索引 ,应 该 创 
建 在 个 (组 ) 属 性 上 。 
A. (Sno, Cno) B. (Sno, degree) C. (Cno, degree) D. degree 








18. 下 列 函 数 中 ,能 返回 数值 表达 式 整数 部 分 值 的 是 s 
A. absO B. int C. signO D. sqrt() 
19. 在 SQL 语句 中 ,检索 去 掉 重 复数 据 , 则 在 select 中 使 用 关键 字 
A. all B. union C. like D. distinct 
20. 下 列 函数 中 ,能 获取 当前 系统 日 期 和 时 间 的 函数 是 E 
A. curdate() B. curtime() C. sysdate() D. date format( 
二 、 填空 题 (每 空 1 分 , 共 10 2) 
1. 数据 模型 通常 由 3 部 分 组 成 , 即 \ 数 据 操作 和 完整 性 约束 。 
2. 以 @@ 作 为 首部 的 变量 在 MySQL 系统 中 称 为 
3. 如 果 使 用 关键 字 , 则 即使 在 更 新 过 程 中 出 现 错误 ,更 新 语句 也 不 会 中 断 。 
4. 在 where 子 句 中 ,关系 运算 符 “<>” 与 关系 运算 符 等 价 ,而 逻辑 运算 符 
“&&.” 则 与 等 价 。 
5. 要 查询 student 表 中 name 字段 值 以 字符 “m” 开 始 , 以 字符 “d” 结 束 的 记录 应 该 在 
where 子 句 后 跟 like Y 
6. 聚合 函数 中 ,用 于 求 出 某 个 字段 平均 值 的 函数 是 
7. 使 用 order by 对 查询 结果 进行 排序 时 ,默认 是 按 顺序 排列 ,也 可 以 按 
顺序 排列 。 
8. 是 特殊 类 型 的 存储 过 程 , 它 能 在 任何 试图 改变 表 中 由 触发 器 保护 的 数据 时 
执行 。 
三 、 阅 读 程序 ,指出 下 列 程序 段 的 功能 (每 题 3 分 , 共 18 分 ) 第 
l. select case 2 when 1 then 'one' 3 
when 2 then 'two' 部 
分 
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else 'more' 
end case ; 

2. alter table book 

add index BkNameIdx( bookname(30) ); 

show index from book VG 
3. select sno,sname from student 

where exists(select * from score 

where students. sno = score. sno and final» 90); 

4. alter table student 

add column comment text not null; 
5. mysqldump -u root - p booksDB books > D:/backup/books 20170707.sql 
6. C: V» nysqlbinlog D:/MySQL/1og/binlog. 000011 
、 简 答题 (每 题 3 分 , 共 12 分 ) 
1. 简要 说 明 事 务 的 隔离 性 的 特点 。 
2. 使 用 直接 复制 方法 实现 数据 库 备 份 与 恢复 时 ,需要 注意 哪些 事项 ? 
3. 简 述 数据 完整 性 的 实现 方法 和 作用 。 
A. 简 述 存储 过 程 的 优点 。 
五 、 综 合 题 (每 小 题 4 分 , 共 40 分 ) 
使 用 MySQL 语句 完成 操作 ,在 数据 库 product. sales 中 参考 下 列表 的 结构 : 


product (产品 编号 char(10) primary key, 
分 类 号 char(6), 
产品 名 char(30) not null unique, 
库存 量 int, 
订货 点 int, 
单价 float(5,2)) 
order_details( 产 品 编号 char(10) references product( 产 品 编号 )， 
订单 编号 char(10) references c_order( 订 单 编号 )， 
订购 数量 (int)) 
c_order( 订 单 编号 char(10) primary key, 
客户 编号 char(10) references consumer( 客 户 编号 )， 
订购 日 期 datetime) 
consumer (客户 编号 char(10) primary key, 
客户 名 称 varchar(30), 
联系 人 char(16), 
联系 电话 char(12)) 


. 查询 单价 介 于 50 元 和 100 元 的 产品 。 

. 查询 产品 订购 总 数量 大 于 3500 的 产品 名 称 及 产品 订购 总 数量 。 

. 查询 2017 年 10 月 开始 没有 下 订单 的 客户 信息 。 

. 将 订单 编号 开头 为 *2017” 的 订单 所 订购 的 产品 数量 加 售 。 

. 删除 c order 表 中 所 有 “2015-10-01? 以 前 的 订单 信息 。 

. 查询 所 有 订单 编号 以 “2017” 开 头 的 产品 的 订购 客户 信息 。 

. 给 consumer 表 增 加 一 个 列 “ 备 注 ”, 数 据 类 型 为 text, 不 允许 为 空 。 

. 按 产品 编号 分 组 ,计算 product 表 中 的 每 种 产品 的 库存 量 及 资金 额度 。 输 出 资金 额 


oo x3 0 0c £D pm o 


度 较 大 的 前 10 种 产品 数据 。 

9. 使 用 alter table 语句 在 order details 表 上 的 订单 编号 列 添加 索引 , 取 名 为 index 
details, 

10. 设置 触发 器 tri update. ZME product 表 中 修改 产品 编号 时 ,可 自动 修改 课程 在 
order details 上 的 产品 编号 。 
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MySQL 数据 库 模 拟 试题 5 参考 答案 


一 、 选 择 题 (每 题 1 分 , 共 20 分 ) 
1—5. CDACA 6~10. CAABB 11—15. DCCCC 16—20. AABDC 
二 、 填 空 题 (每 空 1 分 , 共 10 分 ) 
1. 数据 结构 

2. 全 局 变量 

3. ignore 

4. != and 

5. 'm%d' 

6. avgO 

7. 升序 降序 

8. 触发 器 

三 、 阅读 程序 ,指出 下 列 程序 段 的 功能 (每 题 3 分 , 共 18 分 ) 

1. 使 用 case...when 语句 执行 分 支 操作 。 

2. 使 用 alter table 在 bookname 字段 上 添加 索引 ,使 用 show index 语句 查看 表 中 的 索 
引 定义 。 

3. 查询 有 科目 成 绩 超过 90 分 的 学 生 的 学 号 和 姓名 。 

4. 给 student 表 增 加 一 个 列 “ 备 注 ” ,数据 类 型 为 text, 不 允许 为 空 。 

5. 备份 booksDB 数据 库 中 的 books 表 。 

6. 使 用 mysqlbinlog 查看 二 进 制 日 志 。 

四 、 简 答题 (每 题 3 分 , 共 12 分 ) 

1. 隔离 性 是 指 每 个 事务 在 其 自己 的 会 话 空 间 发 生 , 和 其 他 发 生 在 系统 中 的 事务 隔离 ， 
而 且 事务 的 结果 只 有 在 完全 被 执行 后 才能 看 到 。 即 一 个 事务 内 部 的 操作 及 使 用 的 数据 对 并 
发 的 其 他 事务 是 隔离 的 ,并 发 执行 的 各 个 事务 之 间 不 能 互相 干扰 。 该 机 制 是 通过 对 事务 的 
数据 访问 对 象 加 适当 的 锁 ,排斥 其 他 事务 对 同一 数据 库 对 象 的 并 发 操作 来 实现 的 。 

2. 使 用 直接 从 一 个 MySQL 服务 器 复制 文件 到 另 一 个 服务 器 的 方法 ,需要 特别 注意 以 
下 两 点 : 

(1) 两 个 服务 器 必须 使 用 相同 或 兼容 的 MySQL. 版 本 。 

(2) 两 个 服务 器 必须 硬件 结构 相同 或 相似 ,除非 要 复制 的 表 使 用 MyISAM 存储 格式 ， 
这 是 因为 这 种 表 可 以 为 在 不 同 的 硬件 体系 中 共享 数据 提供 保证 。 

3. 在 定义 和 修改 表 结 构 时 ,可 以 通过 定义 与 该 表 相 关 的 完整 性 约束 条 件 ,实现 数据 完 
整 性 约束 。 这 些 约束 条 件 主 要 包括 not null( 非 空 约束 ) primary key EAR) 、unique( 唯 
一 性 约束 ) foreign key( 外 键 参照 完整 性 约束 ) 以 及 check( 检 查 约束 )。 

数据 完整 性 约束 条 件 都 被 存 和 人 系统 的 数据 字典 中 , 当 用 户 操 作 表 中 的 数据 时 ,由 数据 库 
管理 系统 自动 检查 该 操作 是 否 违背 这 些 完整 性 约束 条 件 。 如 果 完 整 性 约束 条 件 涉及 该 表 的 


多 个 属性 列 , 则 必须 定义 在 表 级 上 ,其 他 情况 则 既 可 以 定义 在 列 级 上 也 可 以 定义 在 表 级 上 。 
通过 数据 约束 条 件 的 实际 应 用 ,可 以 实现 监视 数据 输入 过 程 中 出 现 重复 或 错误 等 ,保证 数据 
的 正确 性 、 精 确 性 。 

4. 存储 过 程 是 MySQL 语句 的 集合 。 存 储 过 程 可 以 使 得 程序 执行 效率 更 高 ,安全 性 更 
好 ,因为 过 程 建立 之 后 已 经 编译 并 且 存 储 到 数据 库 , 直 接 写 SQL 就 需要 先 分 析 再 执行 ,因此 
过 程 效率 更 高 ,直接 写 SQL 请 句 会 带 来 安全 性 问题 。 建 立 过 程 不 会 很 耗 系统 资源 ,因为 过 
程 只 是 在 调用 才 执 行 。 

五 、 综 合 题 (每 小 题 4 分 , 共 40 分 ) 

l. select* from product 

where 单价 between 50 and 100; 


2. select p. 产品 名 称 ，sum(od. 订购 数量 ) 
from product as p, Order details as od 
where p. 产品 编号 = od. 产 品 编号 
group by od. 产品 编号 ,p. 产品 名 称 
having sum(od. 订购 数量 )> 3500; 


3. select * from consumer 
where 客户 编号 not in 
(select distinct 客户 编号 
from c order 
where 订购 日 期 >=2017-10-01)7 
4. update Order details set 订购 数量 = 订购 数量 * 2 
where 订单 编号 like '2017 % '; 
5. delete c order 
where 订购 日 期 <'2015 - 10 - 01" 
6. select * from consumer, c order 
on consumer. 客户 编号 = c order. 客户 编号 
where c order. 订单 编号 like '2017 5$ '; 


7. alter table consumer 
add column 备注 text not null; 


8. select 产品 编号 ,count( 库 存量 ), count( 库 存量 ) * 单价 
from product 
group by 产品 编号 
order by count( 库 存量 ) * 单价 desc 
limit 10; 
9. alter table order details 
add index index details (订单 编号 ); 


10. create trigger tri update 
after update on product for each row 
update order details set order_details. 产品 编号 = new. 产 品 编号 
where order_details. 产品 编号 = old. 产 品 编号 ; 
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MySQL 数据 库 模 拟 试题 6 


说 明 : 本 试题 为 笔试 方式 ,考试 时 间 100 分 钟 ,总 计 100 分 。 
一 、 选 择 题 ( 每 题 1 分 , 共 20 分) 


1. 运算 符 % 能 够 用 于 类 型 的 数据 上 。 
A. float B. char C. smallint D. date 
2. 执行 下 面 语 句 的 结果 是 
Select  upper(ltrim(rtrim('  Hello,world  '))); 
A. 'HELLO.WORLD' B. 'Hello. world ' 
C. 'Hello. world' D. ' HELLO.WORLD ' 
3. 在 关系 数据 库 中 ,能够 唯一 地 标识 一 个 记录 的 属性 或 属性 的 组 合 , 称 为 
A. 主 码 B. 属性 C. 关系 D. 域 
4. 在 SQL select 语句 中 用 于 实现 关系 的 选择 运算 的 短语 是 o 
A. for B. while C. where D. condition 
5. 使 用 show 语句 查看 现在 的 数据 库 中 表 的 命令 是 o 
A. show databases; B. create database; 
C. use mysqltest; C[n] 4) D. show tables; 
6. 用 于 显示 表 的 结构 的 命令 是 
A. create table B. describe 
C. insert D. update 


7. 设 有 图 书 管理 数据 库 


图 书 ( 总 编号 C(6), 分 类 号 C(8), 书 名 Cc(16), 作 者 c(6), 出 版 单位 C(20), 单 价 N(6,2)) 
读者 ( 借 书 证 号 C(4), 单 位 C(8), 姓 名 Cc(6), 性 别 c(2), 职 称 C(6), 地 址 C(20)) 
借阅 ( 借 书证 号 C(4), 总 编号 C(6), 借 书 日 期 p(8)) 
对 于 图 书 管理 数据 库 , 检 索 借阅 了 《网 络 技术 ) 一 书 的 借 书证 号 。 下 面 SQL 语句 正确 的 
是 


select 借 书证 号 from 借阅 where 总 编号 = i 


A. (select 借 书 证 号 from 图 书 where 书 名 一 "网 络 技术 "”) 

B. (elect 总 编号 from 图 书 where 书 名 一" 网 络 技术 "”) 

C. (select 借 书 证 号 from 借阅 where 书 名 一 "网 络 技术 ") 

D. (elect 总 编号 from 借阅 where 书 名 一" 网 络 技术 ") 
8. 修改 自己 的 MySQL 服务 器 密码 的 命令 是 č - 

A. mysql B. grant 


C. set password D. change password 


9. XT select 语句 以 下 哪 一 个 描述 是 错误 的 ? 
A. select 语句 用 于 查询 一 个 表 或 多 个 表 的 数据 
B. select 语句 属于 数据 操作 语言 (DML) 
C. select 语句 的 列 必须 是 基于 表 的 列 的 
D. select 语句 表示 数据 库 中 一 组 特定 的 数据 记录 


10. 改变 表 名 的 指令 是 š 
A. rename table tl rename to t2; B. rename table t1 to t2; 
C. update name tl to t2; D. change name t1 to t2; 
11. 关系 数据 库 中 ,外 码 (foreign key) 是 


A. 在 一 个 关系 中 定义 了 约束 的 一 个 或 一 组 属性 

B. 在 一 个 关系 中 定义 了 缺 省 值 的 一 个 或 一 组 属性 

C. 在 一 个 关系 中 的 一 个 或 一 组 属性 是 另 一 个 关系 的 主 码 
D. 在 一 个 关系 中 用 于 唯一 标识 元 组 的 一 个 或 一 组 属性 





12. 在 MySQL 中 ,通常 使 用 语句 来 指定 一 个 已 有 数据 库 作 为 当前 工作 数 
据 库 。 
A. using B. used C. uses D. use 
13. MySQL 中 存储 用 户 全 局 权限 的 表 是 
A. table_priv B. procs_priv C. columns_priv D. user 
14. 实现 数据 恢复 的 命令 是 
A. mysqldump B. mysql C. backup D. return 


15. 给 名 字 是 liwen 的 用 户 分 配对 数据 库 studb 中 的 stuinfo 表 的 查询 和 插 和 人 数据 权限 
的 语句 是 o 
A. grant select,insert on studb. stuinfo for'liwen'@ 'localhost' 
B. grant select, insert on studb. stuinfo to 'liwen'@ 'localhost' 
C. grant'liwen'@ 'localhost' to select.insert for studb. stuinfo 


D. grant 'liwen'(2 'localhost' to studb. stuinfo on select.insert 





16. 以 下 语句 用 于 撤销 权限 。 
A. delete B. drop C. revoke D. update 
17. 下 面 选 项 中 不 属于 存储 过 程 的 优点 的 是 
A. 增强 代码 的 重用 性 和 共享 性 B. 可 以 运行 加 快速 度 ,减少 网 络 流量 
C. 可 以 作为 安全 性 机 制 D. 编辑 简单 
18.“ 一 个 事务 对 数据 库 的 所 有 操作 ,是 一 个 不 可 分 割 的 工作 单元 ,这 些 操 作 要 么 全 部 
执行 要 么 什么 也 不 做 ”, 这 是 事务 的 
A. 原子 性 B. 一 致 性 C. 隔离 性 D. 持久 性 
19. EFF T 对 数据 R 已 经 加 了 X 锁 , 则 其 他 事务 对 数据 R 
A. 可 以 加 S 锁 不 能 加 X 锁 B. 不 能 加 S 锁 可 以 加 X 锁 
C. 可 以 加 S 锁 也 可 以 加 X 锁 D. 不 能 加 任何 锁 第 
20. 并 发 操作 会 带 来 数据 不 一 致 性 。 3 
A. 丢失 更 新 .不 可 重复 读 、 脏 读 , 死 锁 B. 不 可 重复 读 、 脏 读 、 死 锁 pi 
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C. 丢失 更 新 、 不 可 重复 读 、 脏 读 


二 、 判断 题 (每 题 1 分, 共 10 分) 


c 0 - Oo Oc Uwe 
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. or 关键 字 和 and 关键 字 可 以 一 起 使 用 ,但 是 or 的 优先 级 高 于 and. 

. 在 关键 字 in 之 前 使 用 not 关键 字 可 以 查询 不 在 指定 集合 范围 内 的 记录 。 
. distinct 关键 字 只 能 作用 于 一 个 字段 。 
. 在 对 字符 串 进行 模糊 查询 中 ,一 个 下 画 线 通配符 可 匹配 多 个 字符 。 
. having 关键 字 和 where 关键 字 后 可 以 使 用 聚合 函数 。 
.触发 器 与 约束 发 生 冲 突 ,触发 器 将 不 执行 。 

. 创建 唯一 性 索引 的 列 可 以 有 一 些 重 复 的 值 。 

. 恢复 是 利用 元 余数 据 来 重建 数据 库 的 。 

. 事务 是 并 发 控制 的 基本 单位 。 


视图 本 身 没有 保存 数据 ,而 是 保存 一 条 查询 语句 。 


、 阅 读 程 序 ,指出 下 列 程序 段 的 功能 (每 题 3 分 , 共 18 分 ) 


Create trigger trigger_update after update on kc for each row 
update xs kc set xs kc.kno = new. kno where xs kc. kno = old. kno; 


. select score. sno, score. cno, tname 


from teacher,teach, score 


where teach.cno- score.cno and teacher. tno = teach. tno and tname = ' 陈 宜 '; 


- create view stu glass (id, name, glass) 


as 
select student.s id,student.name ,stu info.glass 
from student ,stu info 

where student. s_id = stu info.s id; 

select * from stu glass; 


. delimiter $$ 


create procedure select score(in xh char(6),kch char(6)) 
begin 
select * from score where s no- xh andc no-kch; 
end $$ 
delimiter ; 


. insert into user (Host, User, Password) 


values( 'localhost', customer', password( custword')); 


. mysql -u root - p booksDB < D: /backup/booksdb 201707. sql 
、 简 答题 (每 题 3 分 , 共 12 分 ) 

. 简 述 利用 union 运算 符合 并 结果 集 时 ,对 结果 集 有 什么 要 求 。 
. 简 述 使 用 PHP 进行 MySQL 数据 库 编 程 的 基本 步骤 。 
. 简 述 游标 在 存储 过 程 中 的 作用 。 

. 简 述 使 用 索引 的 优点 。 

五 、 按 要 求 绘 制 E-R 图 操作 ,并 设计 关系 (第 1 题 8 分 ,第 2.3 每 题 4 分 , 共 16 分) 


D. 丢失 更 新 、 不 可 重复 读 、 死 锁 


一 一 一 一 一 一 一 一 一 一 
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某 企 业 集团 有 若干 工厂 ,每 个 工厂 生产 多 种 产品 , 且 每 一 种 产品 可 以 在 多 个 工厂 生产 ， 
每 个 工厂 按照 固定 的 计划 数量 生产 产品 ; 每 个 工厂 聘用 多 名 职工 , 且 每 名 职工 只 能 在 一 个 
工厂 工作 ,工厂 聘用 职工 有 聘 期 和 工资 。 其 中 : 


工厂 的 属性 有 工厂 编号 、 厂 名 、 地 址 ; 

产品 的 属性 有 产品 号 ,产品 名、 规格 ; 

职工 的 属性 有 职工 号 、 姓 名 、 电 话 、 地 址 。 

1. 设计 满足 上 述 要 求 的 E-R 图 , 注 明 属性 。( 根 据 自己 的 理解 ,用 下 面 线 标明 每 个 实体 
中 的 主 码 )。 

2. 将 E-R 图 转换 为 等 价 的 关系 模型 方式 。 

3. 指出 转换 结果 中 每 个 关系 模式 的 主 码 和 外 码 。 

六 、 根 据 下 列 数据 库 中 表 的 结构 , 写 出 MySQL 语句 (每 小 题 3 分 , 共 24 分) 


student( 
学 号 char(8) primary key, 
姓名 char(8), 
班级 char(10), 
TESI char(2), 
出 生日 期 datetime, 
出 生 城市 char(20), 
人 学 成 绩 tinyint) 
course( 
课程 号 char(6) primary key, 
课程 名 char(20)) 
c select( 
学 期 char(2)， 
学 号 char(8) references student( 学 号 )， 
课程 号 char(6) references course( 课 程 号 )， 
成 绩 tinyint check( 成 绩 >= 0 and 成 绩 <= 100) 


. 查询 缺少 成 绩 的 student 的 学 号 和 相应 的 课程 号 。 

. 查询 1803 物流 班 全 体 学 生 的 学 号 与 姓名 , 且 按照 人 学 成 绩 的 降序 排列 。 
. 统计 班级 的 平均 人 学 总 分 在 650 分 以 上 的 班级 和 这 些 班级 的 平均 人 学 总 
查询 选修 了 ' 实 用 英语 课程 的 学 生 的 学 号 ,以 及 实用 英语 的 成 绩 。 

. 查询 第 2 学 期 所 选课 程 平均 成 绩 前 3 名 的 那些 学 生 的 学 号 和 姓名 。 

. 在 student 表 上 增加 一 个 image 列 ,存放 照片 。 

. 修改 student 表 上 “出 生日 期 " 列 , 使 其 类 型 为 date, 

.将 course 表 的 select 和 update 权限 授予 数据 库 用 户 user2。 
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MySQL 数据 库 模 拟 试题 6 参考 答案 


一 、 选 择 题 (每 题 1 分 , 共 20 分 ) 

75. CAACD 6-—10. BBCCB 11—15. CDDBB 16 一 20. CDADC 

、 判 断 题 ( 每 题 1 分 , 共 10 分 ) 

F 2.T 3.F 4 F 5.F 6.T. 7,FP 8.T 9. T 10. T 

、 阅 读 程 序 ,指出 下 列 程序 段 的 功能 (每 题 3 分, 共 18 分 ) 

. 假设 之 前 创建 的 KC 表 没 有 设置 外 键 级 联 策略 ,设置 触发 器 ,实现 在 KC 表 中 修改 课 
号 时 ,可 自动 修改 课程 在 xs kc 上 的 课程 ID 号 。 

. 查询 教师 “ 陈 宜 ”授课 的 课程 号 和 课程 名 。 

. 在 表 student MÆ stu. info 上 创建 视图 stu_glass, 并 浏览 视图 。 

. 创建 存储 过 程 select_score, 输 出 指定 课程 号 和 学 号 的 学 生成 绩 。 

5. 使 用 insert 创建 一 个 用 户 名 为 customer 的 新 账户 ,主机 名 称 为 localhost, 密码 为 
custword, 

6. 使 用 MySQL 命令 将 D: VNbackupVbooksdb. 201707. sql 文件 中 的 备份 导入 到 数据 
库 中 。 

四 、 简 答题 (每 题 3 分 , 共 12 分 ) 

1. union 运算 符 可 以 将 两 个 或 两 个 以 上 的 select 语句 的 查询 结果 集合 合并 成 一 个 结果 
集合 显示 。 合 并 结果 集 时 ,查询 结果 的 列 标题 为 第 一 个 查询 语句 的 列 标题 。 因 此 ,要 定义 列 
标题 必须 在 第 一 个 查询 语句 中 定义 。 要 对 联合 查询 结果 排序 时 ,也 必须 使 用 第 一 查询 语句 
中 的 列 名 、 列 标题 或 者 列 序号 。 

在 使 用 union 运算 符 时 ,应 保证 每 个 查询 语句 的 选择 列表 中 有 相同 数量 的 表达 式 , 并 且 
每 个 查询 选择 表达 式 应 具有 相同 的 数据 类 型 ,或 是 可 以 自动 将 它们 转换 为 相同 的 数据 类 型 。 
在 自动 转换 时 ,对 于 数值 类 型 ,系统 将 低 精 度 的 数据 类 型 转换 为 高 精度 的 数据 类 型 。 

2. 使 用 PHP 进行 MySQL 数据 库 编 程 的 基本 步骤 如 下 : 

CD 首先 建立 与 MySQL 数据 库 服 务 器 的 连接 。 

(2) 然后 选择 要 对 其 进行 操作 的 数据 库 。 

(3) 再 执行 相应 的 数据 库 操 作 ,包括 对 数据 的 添加 、 删 除 .修改 和 查询 等 。 

3. 游标 是 一 个 被 select 语句 检索 出 来 的 结果 集 。 在 存储 了 游标 后 ,应 用 程序 或 用 户 就 
可 以 根据 需要 滚动 或 浏览 其 中 的 数据 。 

4. 在 数据 库 中 使 用 索引 的 优点 如 下 。 

CD 加 速 数据 检索 : 索引 能 够 以 一 列 或 多 列 值 为 基础 实现 快速 查找 数据 行 。 

(2) 优化 查询 : 查询 优化 器 是 依赖 于 索引 起 作用 的 .索引 能 够 加 速 连接 、 排 序 和 分 组 等 
操作 。 

(3) 强制 实施 行 的 唯一 性 : 通过 给 列 创建 唯一 索引 ,可 以 保证 表 中 的 数据 不 重复 。 


= 


moei 


o 


RI 


SC) N 


需要 注意 的 是 ,索引 并 不 是 越 多 越 好 ,要 正确 认识 索引 的 重要 性 和 设计 原则 ,创建 合适 
的 索引 。 

五 、 按 要 求 绘制 E-R 图 操作 ,并 设计 关系 (第 1 题 8 分 ,第 2.3 每 题 4 分 , 共 16 分 ) 

1. 绘制 E-R 图 如 图 1 所 示 。 









































"一 | 职工 地 址 


1 企业 产品 ER 图 
2. 将 E-R 图 转换 为 等 价 的 关系 模型 方式 。 


工厂 (工厂 编号 , 厂 名 , 地址) 

产品 (产品 号 ,产品 名 ,规格 ) 

职工 (职工 号 ,姓名 ,地 址 ,电话 ,工厂 编号 , 聘 期 ,工资 ) 
生产 (工厂 编号 , 产品 编号 ,数量 ) 


3. 指出 转换 结果 中 每 个 关系 模式 的 主 码 和 外 码 。 


工厂 关系 主 码 : 工厂 编号 , 外 码 : 无 

产品 关系 主 码 : 产品 编号 , 外 码 : 无 

职工 关系 EB: RIS, 外 码 : 工厂 编号 

生产 关系 主 码 : 工厂 编号 和 产品 编号 , 外 码 : 工厂 编号 和 产品 编号 


六 、 根 据 下列 数 据 库 中 表 的 结构 , 写 出 MySQL 语句 (每 小 题 3 分 , 共 24 分 ) 
. select 学 号 ,课程 号 from c_select 
where 成 绩 is null; 
2. select 学 号 ,姓名 from student 
where 班级 = 1803 物流 ' 
order by 人 学 成 绩 desc; 
3. select 班级 ,avg( 人 学 成 绩 ) from student 
group by 班级 ; 
having avg( 人 学 成 绩 )> 650; 
4. select 学 号 ,成 绩 from c select 
where 课程 号 = (select 课程 号 
from course 
where 课程 名 = ' 实 用 英语 ' 
E 
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select c_select. 学 号 ,student .姓名 
from c_select, student 
where c_select. 学 期 = '2'and c_select. 学 号 = student .学 号 
group byc_select. 学 号 
order by avg( 成 绩 ) 
limit 3; 
alter table student add column image blob; 
alter table student modify column 出 生日 期 date; 


grant select, update on course touser2(9 localhost; 
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感谢 您 一 直 以 来 对 清华 版 图 书 的 支持 和 爱护 。 为 了 配合 本 书 的 使 用 ,本 书 





























提供 配套 的 资源 ,有 需求 的 读者 请 扫描 下 方 的 " 书 圈 " 微 信 公 众 号 二 维 码 ,在 医 
书 专区 下 载 ,也 可 以 拨打 电话 或 发 送 电子 邮件 咨询 。 












































如 果 您 在 使 用 本 书 的 过 程 中 遇 到 了 什么 问题 ,或 者 有 相关 图 书 出 版 计划 ， 
也 请 您 发 邮件 告诉 我 们 ,以 便 我 们 更 好 地 为 您 服务 。 











我 们 的 联系 方式 : 
地 dk: 北京 海淀 区 双 清 路 学 研 大 厦 A Bs 707 


邮 编 : 100084 资源 下 载 、 样 书 申请 





电 W: 010— 62770175 — 4604 
资源 下 载 : http://www. tup. com. cn 
电子 邮件 : weijjQ tup. tsinghua. edu. cn 318 
QQ: 883604( 请 写 明 您 的 单位 和 姓名 ) 


用 微 信 扫 一 扫 右 边 的 二 维 码 , 即 可 关注 清华 大 学 出 版 社 公众 号 “ 书 圈 "。 


